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provides a primary mode of operation and a secondary mode of operation and includes control logic configured to selectively change 
the mode of operation of the electronically operated appliance. A communication device adapted to be held in the hand of a user is 
configured to cooperate with the transmitter and the receiver to impart instmcdons wirclessly to the control logic in order to change 

^ the mode of operation of the electiDnically operated appliance upon receipt of a command firom a user. A method of exchanging data 

^ wiielessly between an apparatus and a communication device is also disclosed. 



(57) Abstract: A wireless data exchange system is disclosed The system includes an electronically operated appliance including 
a transmitter, a receiver, and a control module configured to conmiunicate with the transmitter and receiver. The control module 
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SYSTEM AND METHOD FOR WIRELESS DATA EXCHANGE BETWEEN AN 
APPLIANCE AND AHANDHELD DEVICE 

5 

CROSS-REFERENCE TO RELATED APPLICATIONS 

This application claims the benefit of U. S. Provisional Patent Application Serial 
No. 60/267,441 entitled, "Remotely Managed Automatic Dispensing Apparatus and 
10 Method", filed on February 8, 2001, and U. S. Provisional Patent Application Serial No. 
60^0,898 entitled, "Remotely Managed Automatic Disprasmg Apparatus and Method", 
filed on October 24, 2000, both of which are hereby incorporated by reference herein. 

15 BACKGROUND OF INVENTION 

1. FfeWoftnefayentiQn 

The present mvention relates generally to the field wireless data communications, 
20 and more particularly, to data communication between a handheld device having an 
optical interface port that transmits and receives signals witii an optical interface port of 
an electronically operated appliance. 

2. T^chpjy^ B^ckgyound 

25 

Standard infiared (IR) devices communicate in accordance with the Infirared Data 
Association Serial Infrared Physical Layer Specification (hereinafter referred to as the . 
Serial Inftared Specification) promulgated by the Infrared Data Association (IrDA). The 
IrDA is a standard body that publishes specifications containing the criteria by \^ch IR 
30 device manufacturers must comply in order to claim IrDA compliance. The Infirared 
Data Association Serial Infirared Specification is incorporated herein by reference. 

The physical layer specification governs point-to-point communication between 
electronic devices, such as computers and peripherals, using directed half-diqpl^x, serial 
35 infirared communication links through free space. The physical elements, including the 
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Optical links and active input and ou^ut inter&ces, are described in ttie physical layer 
specificatioa In order for a device to be IrDA compliant, the device must be designed to 
meet the specifications as indicated in the physical layer specification. 

S La particular, the IrDA Physical Layer Specification places constraints on the * 

communication procedure when a device attempts to establish an optical link with a 
second device. The IrDA Physical Layer Specification sets forth requirements that govern 
the behavior of a device having a transmitter/detector pair when establishing an optical 
link. Compliance with the IrDA Physical Layer Specification requires that the device 
10 sample its detection range. An IrDA compliant device will not transmit a pulse to 
another device to request a link imtil it detects 500 msecs of **media quiet'* **Media 
quiet" means that there is no IR activity detected during the 500 msec duration. 

Once an optical link is established between two devices, IrDA compliance 
15 requires that a serial interaction pulse (SIP) be emitted eveiy 500 msecs to quiet otiier 
potentially interfering systems. In other words, tiie 500 msec "media quief * requirement 
will ensure tiiat the potentially mterfering device detects an SIP every 500 pisecs thereby 
precluding the device fit>m attempting to establish a connection. 

20 The SIP is required by the Physical Layer Specification to quiet slower systems 

that might interfere with the optical link established between the transmitter and the 
receiver. An SIP is a 1.6 microsecond pulse followed by a 7.1 microsecond off time of 
the transmitter. The SIP simulates a start pulse that requires a potentially interfering 
system to listen for at least 500 milliseconds prior to establishing an optical link. 

25 

In accordance with the Physical Layer Specification, optical sensors are 
commonly employed with IR transmitters which, together with processing electronics, 
are used to detect an object in the range of the IR transmitter. An IR pulse is emitted, and 
if it strikes an object in its range, the ptilse is reflected. An IR sensor is placed 
30 strategically in order to detect the reflected pulse. 
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The dichotomous emittei/seDSor technology is eiqployed m various applications 
including electronically activated fluid dispensing devices. Such dispensing systems, 
such as hand activated water faucets, generally include an infiared emitter that emits a 
timed pulse. When an object, such as a user's hands, is within the emitter's range, it 
5 reflects the pulsed JR beam, and the optical sensor detects the reflected light from the 
user's hands. In such a system, an IrDA compUant device emits a pulse every 250 
milliseconds. 

Various methods have been employed to electronically control water flow through 
10 a water control device such as a faucet or spigot Among flie accepted methods is the use 
of an optical sensor typically employed in combination with an infiared CTR**) source or 
IR emitter that together with processing electronics, are used to control a solenoid valve. 
Generally speaking, a pulsed IR beam is reflected from an object (such as a user's hands 
or other body parts, for example) and sensed by a photo detector to determine whether to 
IS activate or deactivate the solenoid valve. Pulsed IR sensing remains at the forefront of 
sensing techniques used with these types of devices, due in part to its reasonable 
perfoimance and low cost 

Automatically activated fluid dispensing devices commonly known in the art do 
20 have a myriad of operating shortcomings. For example, devices such as IR controlled 
faucets require extensive manual servicing and maintenance. Inherently, in an 
environment such as an ofBce building having numerous floors and numerous &ucets in 
each of the restrooms on each of the floors, servicing and maintenance of the IR 
controlled devices is often a burdensome and time consuming task. Many simple tasks 
25 associated with the maintenance of the faucets, including battery replacement, IR range 
monitoring, and solenoid malfunction detection, are typically manually performed per 
faucet per restroom per floor in an office building. This type of monitoring of 
malfrmctioning imits dictates manual interaction with each imit for diagnostics, 
maintenance, calibmtion, and servicing. 

30 
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In addition^ a common denominator for many of the problems associated with 
automatically activated flow control devices, such as &ucet5» is the environment in which 
such devices are installed and operate. For instance, existing IR sensor designs generally 
suffer from an inability to adapt to changes in the background signal level associated with 
S a gradual discoloration of the sink in which the &ucet is mounted, a gradual degradation 
of fht sensor lens due to the use of abrasive cleaning compounds, a gradual degradation 
of flie IR emitter performance, among other things. Generally, existing sensors employ a 
fixed sensitivity threshold that is set either at the factory or by the installer (or both). 
When the IR sensor sensitivity is fixed, the sensors performance will inevitably degrade 
10 with environmental changes, and when the degradation causes faulty operation, a service 
call may be required In some instances, the gradual degradation will go unnoticed 
resulting in poor performance. 

In addition, calibration of today's automatically activated flow control devices is 
IS often labor intensive and inefGcient with respect to devices presently on the market. The 
low cost IR sensing devices employed in automatically activated flow control devices 
vary with respect to power reqmrements, performance, and other criteria. As a result, 
readmgs taken by these IR sensing units (such as whether a user's hands are present 
beneath the aerator of a &ucet) are generally non-unifoim firom device to device and, 
20 therefore, often result in improper activation and deactivation of some devices. 
Similarly, as battery power for these devices decreases over time, so does fb& power 
ou^ut of the IR sensing devices. As a result, manual calibration of conventional 
automatically activated flow control devices is generally required during initial 
installation, and thereafter on a firequent basis following extended periods of use. 

25 

Unfortunately, vandalism and water damage also adversely affect ttie use and 
proper operation of automatically activated flow control devices presently available in the 
art. Water often travels along the wiring harness extending from the flow control device 
to the device's electronics causing corrosion to the parts. In addition, vandals may 
30 attempt to break into the electronics box associated with the device or pull the wires from 
either the electronics box or the faucet. 
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What is needed therefore, hut presently unavailable in the art is a system and 
method of wireless two-way data exchange between an appliance such as, an 
electronically activated flow control device, and a handheld device that overcomes many 
5 of the shortcomings associated with electronically activated appliances presently 
available in the art Such a system and method should be easily maintained by 
maintenance personnel, substantially impervious to vandalism, self-calibrating, and 
remotely controlled. In addition, the system of the present invention should be capable of 
being remotely managed and controlled by any nimiber of portable communication 

10 devices presently available in the art The system should consume low power, be easy to 
install, and low cost. Moreover, the system should be capable of receiving instruction 
from a remote IRDA emitting device despite the appliances rapid rate of euMtted IR 
sensing pulses. Large numbers of appliances within the system should also be capable of 
being used in a distributed network environment, and should be adapted to be managed 

IS and controlled from as few as one centralized control point It is to the provision of such 
a system and method that the present invention is primarily directed 

SUMMARY OF TBDE BSrvrmiON 

20 One aspect of the present invention relates to a wireless data exchange system. 

The wireless data exchange system of the present invention includes an electronically 
operated appliance having a transmitter, a receive, and a control module configured to 
communicate with the transmitter and the receiver. The control module is configured to 
provide a primary mode of opemtion and a secondary mode of operation and includes 

25 control logic configured to selectively change the mode of operation of the electronically 
operated appliance. The system fiirfher includes a communication device adapted to be 
held in the hand of a user. The communication device is configured to cooperate with the 
transmitter and receiver to impart instructions wirelessly to the control logic to change 
the mode of operation of the electronically operated appliance upon receipt of a 

30 command from the user. 
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In another aspect the present invention relates to a method of exchanging data 
wiielessly between an apparatus and a communication device. The method includes the 
steps of sending a wireless dgnal fit>m a handheld communication device to an 
electronically operated ^pliance operating in a primary mode of operation, and changing 
S the mode of operation of the electronically operated appliance fix)m a primary mode of 
operation to a secondary mode of operation in response to the sending step. The method 
further includes the step of establishing a two-way wireless communication link for the 
exchange of data between the handheld device and tiie electronically operated appliance 
while the electronically operated appliance is in the secondary mode of operation. 

10 

The remotely managed system and method of the present invention results in a 
number of advantages over conventional electronically activated appliances commonly 
known in the art For example, tiie remotely managed system and method of the present 
invention provides for the efScient servicing and maintenance of multiple remotely 
IS managed electronic dispensing apparatuses positioned in a single room, such as a public 
lestroom. In accordance with the invention, maintenance personnel may sinq)ly enter the 
room with a portable communication device and detennine which if any of the remotely 
managed electronic dispensing apparatuses are defective, or otherwise require servicing. 

20 An additional advantage of the present invention is provided by the cooperation of 

tiie anti-vandalism bracket and strain relief sheath of the present invention. The anti- 
vandalism bracket and strain reUef sheath protect the electronics and the associated cables 
or leads providing a commimication path between the dispensing apparatus and the 
electronics. In the past, separation of tiie leads from the electronics often resulted from 

25 individuals intentionally or otherwise pulling on the leads or associated comiectors. In 
accordance with tiie present invention, these leads are now covered with a protective 
sheath that cooperates witii the anti-vandalism bracket to withstand the pulling forces that 
would otherwise separate the leads from the electronics. The strain relief sheath may also 
provide a drip loop for capturing water that could otherwise damage the electronics, cable 

30 or coimectors. 
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A further advantage to the present invention relates to the system's ability to 
control and manage any number of dispensing ^paratuses from a central controller or 
computer. Hie preferred hubs used in the distributed network environment liable a 
plurality of dispensing apparatuses to be connected to a network via the standard RS232 
5 serial ports provided with traditional electronically activated dispensing apparatuses 
presently available in the art. Moreover, the filtering and calibrating technology 
incorporated in the system of the present invention significantly limits the nimiber of 
false detections and false activations, and therefore reduces the number of instances of 
dispensing apparatus malfimctions, wear and tear on the dispensing apparatuses, and the 
10 waste of fluids dispensed by such dispensing apparatuses. 

Additional features and advantages of the invention will be set forth in the 
detailed description which follows and in part will be readily apparent to those skilled in 
the art from that description or recognized by practicing the invention as described 
IS herein. 

It is to be understood that both the foregoing general description and the 
following detailed description are merely exemplary of the invention, and are intended to 
provide an overview or framework for understanding the nature and character of the 
20 invention as it is claimed. The accompanying dmwinjgs are included to provide frirther 
understanding of the invention, illustrate various embodiments of die invention, and 
together with the description serve to e;q>lain the principles and operation of the 
invention. 

25 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a block diagram illustrating a data communication system in accordance 
with a first preferred embodiment of the present invention. 

30 
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FIG. 2 is a flowchart illustrating the event loop of the control logic 120 in FIG. 1 
of Remote management node of the present invention. 

FIG, 3 is a flowchart illustrating the communication function called by the event 
S loop 114 from the communication function call 122 illustrated in FIG. 2. 

FIG. 4 is a detailed flowchart of the send status command called by the 
communication module 132 from the send status 146 in FIG. 3. 

10 FIG. 5A-5D is a flowchart illustrating the general functionality of the overall 

firmware structure of the fluid dispensing device that forms a part of the first preferred 
embodiment of the system and method of the present inventioit 

FIG. 6A-6C is a flowchart illustrating the Interrupt Driven IR and Battery Thread 
15 of the firmware of the fluid dispensing device that forms a part of the first preferred 
embodiment of the system and method of the present invention. 

FIG. 7A-7G is a flowchart illustrating the IR and Battery Detection Thread of the 
firmware of the fluid dispensing device that forms a part of the preferred embodiment of 
20 the system and method of flie present mventioxL 

FIG. 8A-8D is a flowchart illustrating the Motion Detection Thread of the 
firmware of die fluid dispensing device that forms a part of the first preferred 
embodiment of the system and mettiod of the present inventioiL 

25 

FIG. 9A-9C is a flowchart illustrating the Motion Detection Thread of the 
firmware of the fluid dispensing device that forms a part of the first preferred 
embodiment of the system and method of the present invention. 

30 FIG. 10 is a block diagram illustrating the data unit descriptions of a Broadcast 

signal. 
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FIG. 11 is a block diagram illustratiiig the data linit descriptions of an Attention 

signal. 

5 FIG. 12 is a block diagram illustrating Uxo data unit descriptions of a Connected 

Mode request signal. 

FIG. 13 is a block diagram illustrating the data unit descriptions of a Status 

signal. 

LO 

FIG. 14 is a block diagram illustrating the data unit descriptions of a Set signal. 
FIG. 15 is a block diagram illustrating the data unit descriptions of a Program 

signal. 

15 

FIG. 16 is a block diagram ilhistrating the data unit descriptions of an End signal. 

FIG. 17 is a graphical depiction of the graphical user mterface of a handheld 
computer illustrating five (5) exemplary user options, inchiding three options that 
20 incorporate an optical link with the fluid dispensing device of the present invention, "Get 
Faucet Data", "Adjust Faucetf* , and "Scan For Problems". 

FIG. 18 is a graphical depiction of the graphical user interfece of a handheld 
computer iDustrating the "Get Faucet Data" option form that allows a user to retrieve 
25 current fluid dispensing device parameters. 

FIG. 19 is a graphical depiction of the graphical user interfece of a handheld 
computer illustrating the "Adjust Faucef option form that allows a user to edit current 
fluid dispensing device parameters. 

30 

FIG. 20 is a graphical depiction of the graphical user interface of a handheld 
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computer illustrating tiie ''Scan For Problems" option form that allows a user to retrieve 
Broadcast signals as diagrammed in FIG. 10 from a set of fluid dispensing devices. 

FIG. 21A-B is a flowchart illustrating the overall software flow of the firmware 
5 structure of the fluid dispensing device as shown in BIG. 5A-SD. 

FIG. 22 is a flowchart illustrating &e Broadcast functionality of the fluid 
dispensing device and the data unit that is depicted in FIG. 10. 

10 FIG. 23 is a diagram of a conventional electronically operated dispensing device. 

FIG. 24 is a diagram illustrating a second preferred electronically operated 
dispensing device incorporating a portable conmiunication device in accordance with the 
present invention. 

15 

FIG. 25 is a schematic diagram of an exemplary remotely managed dispensing 
system incorporating the dispensing apparatus depicted in FIG. 24. 

FIGs. 26a-26f depict of exemplary control and information screens displayed by 
20 the portable communication device (PCD) depicted in FIG. 25. 

FIG. 27 is a block diagram illustrating a the preferred elements of the control 
module depicted in FIG. 24. 

25 FIG. 28 is a block diagram illustrating the preferred elements of the transmitting 

portion of the control module depicted in FIG. 27. 

FIG. 29 is a diagram of timing relations for pulses transmitted by die dispensing 
apparatus of FIG. 24. 

30 
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FIG. 30 is a . block diagram illustrating the preferred elements of the receiving 
portion of the control module deleted in FIG. 27. 

FIG. 31 is a diagram illustrating the location of emitter and receiver elements on 
5 the sensor module of tfie dispensing apparatus depicted in FIG. 24. 

FIG. 32a-32c illustrate various views of a front-to-back mounting of photo diodes 
in accordance with a preferred embodiment of the present invention. 

10 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

Reference is now made in detail to a present preferred embodiments of the present 
invention, examples of which are illustrated in the accompanying drawings. Wherever 
15 possible, the same reference numerals will be used throughout the drawing figures to 
refer to the same or like parts. An exemplary embodiment of the data communication 
system and method of Ate present invention is illustrated in the block diagram of FIG. 1 
and is designated generally throughout by reference numeral 98. 

20 In accordance with the invention, the hardware elements of one preferred 

embodiment of tiie data communication system of ttie present invention include Remote 
Management Node 100 and Managed Node 102. Remote Management Node 100 
includes generally an optical interface port 104, a processing element 110, and a memory 
element 112. Managed Node 102 includes generally an optical mter&ce port 106, an 

25 electronics module 114, and a Mechanical Element 123. The optical interface port 106 of 
Managed Node 102 includes an emitter 118 and a detector 116. The emitter 118 has a 
pulse range 119 wherein an object within the arc showing pulse range 119 will reflect a 
pulse transmitted from emitter 118. Communication between Remote Management Node 
100 and Managed Node 102 is accomplished by an optical link 108 in free space between 

30 the optical interface port 104 and 106. 
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The Memoiy Element 112 of Remote Management Node 100 houses the remote 
management control logic 120. Processing element 110 manipulates the optical inter&ce 
port 104. 

S Managed Node 102 further mcludes Mechanical Elements 123, known to those 

skUled in the art, necessary for controlling an electronically operated appliance such as, 
but not limited to, a fluid-dispensing device 102. The electronics 114 include fiirther a 
Managed Node Control Logic 122 that controls functionality of the optical port 106 and 
the manipulation of Mechanical Elements 123. 

10 

The emitter 118 of Managed Node 102 periodically emits a pulse, such as every 
250 milliseconds, for example. The pulse emission creates an optical signal in free space. 
In order for the optical interface port 104 of Remote Management Node 100 to establish 
an optical link with the optical interface port 106 of Managed Node 102 Remote 
15 Management Node Control Logic 120 resides in a memory component 112 of Remote 
Management Node 100. The Remote Management Node Control Logic 120 can be 
implemented in software, hardware, or a combination thereof. 

The Remote Management Node Control Logic 120 causes the emitter 105 to emit 
20 an Attention signal from the optical inter&ce port 104. The Remote Management Node 
Control Logic 120 is managed and manipulated by the microprocessor 110. The attention 
signal that is emitted from the optical inter&ce port 104 is transmitted regardless of its 
detection of a '^edia quiet" environment In other words, the Attention Signal is emitted 
despite the 250-millisecond infrared pulse of the emitter 118 of Managed Node 102. 

25 

As previously described, the electronics 114 in cooperation with the Managed 
Node Control Logic 122 cause the periodic miission of an infi^d pulse from the emitter 
118. In tiiis regard, the emitter 118 causes such an emission every 250 milliseconds. 
Prior to emission of tiie infrared pulse, the detector 116 attempts to detect an attention 
30 signal that is emitted from the optical interface port 104 of Remote Management Node 
100. If an attention signal is not detected, the emitter 118 is allowed to operate normally. 
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emitting an infrared pulse eveiy 250 milliseconds. If, on tiie other hand, an attention 
signal is detected, normal op^tion of the emitter is discontinued and an optical link 108 
is established between the optical interface port 104 and the optical inter&ce port 106. If 
the attention signal is not detected, then normal operation of the emitter 118 continues. 

5 

In the first preferred embodiment of tiie invention Remote Management Node 100 
is a handheld or portable device or computer, and Managed Node 102 is an electronically 
activated fluid dispensing device. During normal operations, the fluid dispensing device 
emits an infrared pulse from emitter 118 every 250 milliseconds. If an object is within 
10 pulse range of the emitted signal, the signal is reflected and the detector 116 detects the 
reflected signal. If the detector 116 detects the reflected signal, then the electronics 114 
will activate a solenoid 101 causing fluid to be dispensed from the faucet assembly. 

A handheld computer 100 aUows a remote user to interrupt the normal operation 
15 of the Managed Node 102. In order for the handheld computer to communicate with the 
Managed Node 102, an optical link 108 is established between the optical interface port 
104 of the handheld computer 100 and the optical inter&ce port 106 of the fluid 
dispensing device 102. The optical link allows a maintenance user to perform various 
maintenance fimction remotely, including retrieving device-specific data stored by the 
20 electronics 114 of the fluid dispensing device 102, adjusting electronics parameters, or 
reprogramming the sofiware that controls the fluid dispensing device. 

HANDHELD COMPUTER SOFTWARE 

25 The Remote Management Node Control Logic 120 (FIG. 1) on the handheld 

computer 100 (FIG. 1) initiates an optical link 108 (FIG. 1) between the optical interface 
ports 104 and 106 in accordance with a user's instruction. A description of the Remote 
Management Node Control Logic on the handheld computer 100 is now described in 
more detail with reference to FIG2, FIG. 3, and FIG. 4. The flow charts are merely 

30 exemplary and other methodologies may be employed to implement the present 
invention. 
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The Remote Management Node Control Logic 120 (FIG. 1) generally controls a 
user interface, input and output to the user interface, and inpiit and output through optical 
interface port 104 (communication between optical interface ports). FIG* 2 is a higji 
5 level illustration of the Remote Management Node Control Logic 120 (FIG. 1). Event 
loop 124 of the Remote Management Node Control Logic 120 (FIG. 1) executes on the 
handheld compute 100. In essence, the event loop monitors input and output activity. 
This monitoring step of the remote management control logic is represented in the event 
loop 124 by the processing symbol 128. When an event occurs, the event loop 124 flien 

10 determines whether the event is one that requires the establishment of an optical link 
between the handheld computer and the fluid dispensing device in decision symbol 130. 
Events that require an optical link uiclude retrieving data from the fluid dispensing device 
102 providing a user data accessibility, reprogramming the Managed Node Control Logic 
122 on the fluid dispensing device 102 (FIG. 1), or reconfiguring electronics parameters 

15 on the fluid dispensing device 102 (FIG. 1). The decision symbol 130 represents that 
part in the control logic where the input retrieved from step 128 is analyzed to determine 
whether the event requires the establishment of an optical link 



If an optical link is not required to perform the fimction requested in step 128 by 
20 the user, then the event loop 124 of the remote management control logic 120 determines 
whether the user has requested that a groi^ of fluid dispensing devices be scanned as 
indicated by decision symbol 134. The scanning of various fluid dispensing devices is 
discussed further herein. If the event does not require tiie scanning of a set of fluid 
disp^ing devices, thm the event requested by the user is processed in step 138 by the 
25 pafan event handlers tihat do not require the establishment of an optical Imk between the 
handheld compute 100 (FIG. 1) and the fluid dispensing device 102 (FIG. 1). 
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If at the decision symbol 130 it is determined that the requested event requires an 
optical link, then ttie communication function is called in processing symbol 132. The 
communication function is illustrated in FIG. 3 and is designated generally throughout as 
reference numeral 142. The communication function is entered from step 132 in FIG. 2 
S at tiie input/ou^iit symbol 144 in FIG. 3. 

The communication function 142 first ascertains the status of the optical interface 
port 104 (FIG. 1) represented by the decision symbol 146 in the communication function 
142. If the port is in a closed state, then the serial port is initialized indicated by the 
10 processing step 148. Once the port is initialized, the IR-State variable is set to OPEN m 
the processing symbol 150. Once the port is initialized and the IR-State is set to OPEN, 
the handheld computer is now configured for communication with the optical inter&ce 
. port 106 (FIG. 1) of fluid dispensing device 102 (FIG. 1). 



IS The commimication function 142 provides six functional capabiUties. Each 

separate fimction is indicated as a different indicator in the gCommand variable. The 
next step 152 is represented by a switch symbol serving as a director to the appropriate 
function as indicated by the gConomand variable. This variable represents the event 
requested by the user. The six functions available are represented by the processing 

20 symbols and include Scanning 154, Send Status 156, Set 158, End 160, Program 162, and 
Idle 164. 



If the user chooses to retrieve from the feucet information about the fluid 
dispensmg device, tixen at processmg symbol 156 the Send Status function 178 m FIG. 4 
25 is called. FIG. 4 illustrates in detail tiie control logic of the Send Status command 
function 178. The Send Status function 178 initially determines if the fluid dispensing 
device is in a coimected mode. This step is represented by the decision symbol 180. The 
connected mode is present when an optical link 108 (FIG. 1) is established. If the 
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connected mode has not hem established, then the lemote man^ement control logic 
initiates an optical signal that is emitted fipom the optical interiacG port 104 (FIG. 1). 
Hiis step is represented by the processing symbol 182. The signal is an Attention Signal 
and is ref^red to throughout as such. FIG. 21 illustrates the logic flow initiated on the 
5 fluid-dispensing device when the handheld device attempts to initiate connected mode. 
FIG. 21 is described further hereiiL 



If the fluid dispensing device is in connected mode, the Send Status command is 
sent as represented by the processing symbol 184. The Send Status command requests 

10 fix)m tiie fluid dispensing device a set of data describing various parameters of the device. 
The set of data includes parameters about the fluid dispensing device including 
information relating to power, settings, and usage. Power information relating to the 
fluid dispensing device includes unloaded volts, loaded volts, time in use, and replace 
battery date. The settings information includes the current operating mode, the range 

15 setting, the range of^et, delayed settmgs, and virtual settings. The usage information 
consists of the number of uses, uses per day, and hours of operation. Other miscellaneous 
information can include current errors, past errors, software version, PCB number, and 
engineering change level. 



20 Once the request for the status is sent in processing step 184, the Send Status 

function 178 determines whether the conmiand was received. This step is indicated in 
the software function 178 by the decision symbol 186. If the request for status 
information was successful, a flag is set in the processing step 188 and the data is 
received by the handheld computer as indicated by the processing symbol 190. The 

25 optical link is then terminated when the handheld computer send the End command in 
step 192. The gCommand variable is set to idle in the processing step 194, an alarm is 
sounded in processing step 196 to indicate to tiie user successfid receipt, and the Send 
Status function exits in processing step 200. 



16 



' wo 02/061955 



PCTAJSOl/50725 



If die Status conunand is not received by the fluid dispensing device, the Send 
Status function 178 exits in processing symbol 200. 

When the Send Status command module 178 exits, control is returned to flie 
5 Communications function 142. In FIG. 3, the Communications function 142 then 
queries the status of Hie IR serial port in decision step 166. If the IR-State is OPEN, the 
receive buffer is flushed in processing step 168, and tiie gCommand variable is queried. 
If the command variable is Idle, then the serial port is closed in processing step 172 and 
the IR-State variable is set CLOSED. The Communications function exits in processing 
10 step 176 returning control of the processing to the event loop 124 (FIG. 2). 

Witibi reference to FIG. 2, the Event Loop 124 then queries the gCoimnand 
variable to determine if scanning is taking place in decision step 134. If scanning is 
taking place then the 'time ouf timer is reset in processing step 136. If the handheld 
15 computer is not scanning a group of fluid dispensing devices, then flie event request is 
handled by functions that do not require the optical communication link 108 in 
processmg step 138. The event loop flien exits in processing step 140. 

20 FLUID DISPENSING DEVICE FIRMWARE 

With reference to FIG. 1, the Managed Node Control Logic 122 of the fluid 
dispensing device 102 is now discussed with reference to FIGS, 21A-B, 5A-5D, 6A-6D, 
and 7A-7D. FIG. 21 illustrates the basic functional blocks of flie fluid-disp^ing device 
25 showing the fiindamental communication components. 

With reference to FIG. 21, flie logic flow of the fluid dispensing device response 
to a request for Connected Mode &om a handheld device is shown and is generally 
referred to tiiroughout as reference numeral 840. The fluid-dispensing device response to 
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a request for connected mode is initiated by an IR sigdal fiom the handheld device as 
shown by the signal transmission block 842. This initiating signal is the Attention Signal 
as discussed infia. During a pulse cycle, vMch is discussed further herein and is 
described in FIG. 5, the detector 116 (FIG. 1) samples its detection range to determine 
5 whelfaer an initiating transmission was sent from the emitter 105 (FIG. 1) in a process 
illustrated by independent process symbol 844. This process samples its detection range 
for the Attention Signal prior to initiating a detection pulse for object reflection. 

The fomjat in which the signal is sent indicates that the signal detected is an 
10 Attention Signal, and those skilled in the art will recognize various ways that the 
Attention Signal can be formatted to accomplish this indication. In a preferred 
embodiment the Attention signal includes a stream of *FF* characters followed by a 
linefeed. Also, the duration of the sigual is greater than the length of the pulse cycle. 

IS Decision symbol 848 illustrates the queiy that determines whether the sample 

received by the detector was an Attention signal (i.e. contained TF' charactCTS followed 
by a linefeed. If the signal detected is not the Attention signal, then the fluid-dispensing 
device continues its normal operation as represented by terminating symbol 850. 

20 If> on the other hand, the Attention Signal is received, the fluid dispensing device 

responds as indicated in independent process symbol 852. In decision symbol 854 tiie 
current state of the water flow is queried. If the water is currentiy on, the water is tumed 
off as indicated by processing symbol 856, prior to responding to the request for 
connected mode. 

25 

In independent processing symbol 858, the command sent by the handheld 
computer is received. The varioixs commands that can be sent by the handheld computer 
are described infra and include Scanning 154, Send Status 156, Set 158, End 160, and 
Program 152 (FIG. 3). 
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A timer starts in processing symbol 860 to retum to normal operation after a fixed 
amount of time. Decision symbol 860 determines whether the End command 160 (as 
shown in FIG. 3 and described supra) has been sent If the End signal is sent, then the 
fluid-dispensing device returns to normal operation in terminating symbol 876. If the 
5 End command has not been detected, then the process 840 determines in decision symbol 
862 whether the entire signal has been sent. If the entire signal has been sent, according 
to the bit count e3q)ected, then the process determines in decision symbol 866 whether the 
entire signal was sent If the command is a valid one, as determined by decision symbol 
870, then the command is decoded and implemented in processing symbol 876. 
10 Connected Mode is then terminated through decision symbol 860 at termination symbol 
876. 

FIGS. 5A-5D illustrate the control logic 122 that controls the electronics 114 
OFIG. 1) of the fluid dispensmg device 102, thereby controlling the communication on 
15 the fluid dispensing device node side of the optical link 108. 

With reference to BIG. 5A, as indicated by the processing qonbol 202, the fluid 
dispensing device is powered on or reset Numerous setup functions are performed in 
processing steps 214-234 (FIG. 5A) and 236-238 (FIG. SB). Specific fimctions related 
20 to data communication operations are indicated by processing symbol 230 including 
initializing the input/output ports, CPU peripheral initialization, and time base module 
(TBM) process 236 (FIG. SB) initialization. The TBM is responsible for the tinting of the 
IR pulse every 250 milliseconds. It performs the real time interrupt that occurs every 250 
milUseconds for cycle timing, and it monitors seconds and hours. 

25 

With reference to FIG. SB, a pulse cycle includes generally powering up the 
microprocessor, attempting the detection of the Attention signal emitted by tiie handheld 
computer, emitting a pulse fix)m the fluid dispensing device emitter, and powering down 
the microprocessor. The processing symbol 240 is the first processing symbol in this 
30 process. It indicates that the process element included in the electronics component 114 
(FIG. 1) is powered off as a first step in a pulse cycle. The TBM determines tiiat 250 
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milliseconds have elapsed, and the microprocessor is awakened as indicated by 
processing symbol 242. In this processing step, the overall firmware process 202 also 
waits for tihie phase-locked loop to lock in order to maintain a constant 4.0 MHz for 
normal operation. 

5 

The processmg symbol 244 represents the initiation of the interrupt driven IR and 
Battery Sanq)ling Routine. The interrupt driven IR and Battery Sampling Routine is now 
discussed with reference to BIG, 6A and 6B. The Interrupt Driven IR and Battery 
Sampling Routine begins at input symbol 328 in JIG. 6A and is designated general 
1 0 throughout as reference numeral 326. 

The IR and Battery Sampling Routine is interrupt driven and is generally 
responsible for sampling the battery voltage and obtaining a reflected sample of an IR 
pulse from the emitter 118 (FIG. 1). The processing step 330 represents the sampling 

15 and saving of a battery voltage reading. The decision step in 332 determines whether the 
battery voltage is extremely low. If the battery voltage is low, then the IR and Battery 
Sampling Routine 326 returns to the overall firmware program 202 represented by the 
output symbol 364 in FIG. 6B. If flie battery voltage is not low, then the IR receiver is 
powered on, which is represented by processing symbol 334. In decision symbol 336, the 

20 optical sensor flag is examined to determine if tiie detector 116 (FIG. 1) is connected. If 
the optical sensor flag mdicates that the detector 116 (FIG. 1) is unplugged, only the 
loaded battery voltage is sanipled. In processmg step 338 the MOSFET is turned on, the 
loaded battery voltage is sampled and saved, as represented by processmg step 340. The 
Analog to Digital Converter (ADC) is flien turned ofl^ as represented by processing step 

25 342. Routme 326 then exits in terminator symbol detector 364 (FIG. 6B) 

If Ae detector is not unplugged, as indicated in decision step 336, then the 
Routine 326 waits for the 3 volt power supply to stabilize, as indicated by processing step 
344. 

30 
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In processing symbol 346 the range on the optical sensor is set to low or high, and 
the IR transmit regulator is enabled to initiate a pulse. With reference to FIG. 6B, once 
the infrared transmit pulse is enabled, the Routine 326 waits for the pulse time then tests 
the detector 116 to determine a reflection in processing symbols 348 and 350, 
5 respectively. The IR transmit is then disabled in processing step 352. Processing step 
354 indicates that an additional delay of approximately 7 microseconds is allowed so that 
an entire reflection sample can be detected. The reflected IR is sampled and saved just 
before the pulse peak in processing step 356. Once the reflected pulse is completed, the 
IR ambient level is sampled and saved in processing step 360. The IR receiver and the 
10 ADC are then turned oS. The IR and Battery Sampling Routine 326 then returns to the 
thread handler in EIG. 5. 

Processing step 246 represents enabling tixe switch input tiiread that is executed 
every 2 seconds. This thread queries the necessary input mode and makes changes 
15 accordingly. 

Processing step 248 represents a *1cemel" loop that cycles through and calls each 
of the other active threads. Each thread has separate phases, which are typically run once 
each thread call, and control movement to the next phase. Thread diagrams show one 
20 phase of the same thread run directiy after the last Any other active threads and their 
current phases would run before the same thread is accessed again. 

The next processing symbol 250 r^resents a thread that is responsible for 
perfomodng analog conditioning and error checking on values obtained from the battery 
25 and the infrared receiver. FIG. 7 is a flow chart of the Analog Conditioning and Error 
Checking Thread represented by the processing step 250. The program starts at input 
symbol 368 in FIG. 7A. 

The thread represented by FIG. 7 has four phases including phase 0, phase 1, 
30 phase 2, and phase 3. Phase 0 performs an analysis on the battery voltage level of the 
system and makes adjustments in the system to compensate for voltage changes. Phase 0 
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begins in processing step 370 in FIG. 7A with a battery sample fix>m the IR and Battery 
Sampling Routine 326 illustrated in FIG. 6. The voltage of the battery is initially 
sanqpled at calibration time. The calibration voltage is stored and is used in detennining 
the operating voltage of the systenL The calibration voltage is compared to a standard 
S value fliat is a constant vahie stored in the system. Standard voltage is a constant 
expected value of the voltage of the system under normal conditions. The calibration 
voltage and the standard voltage are compared as indicated by the decision symbol 372. 
The current real-time battery voltage is flien calculated. If calibration voltage is greater 
than the standard voltage, then the battery voltage is determined as represented by 

10 processing symbol 374, subtracting from the sample obtained from the IR and Battery 
Sampling Routine 326 the difference between the calibration voltage and the standard 
voltage. If the standard voltage is greater than the calibration voltage, then the current 
real-time battery voltage is determined as represented by processing symbol 376, adding 
to the sample voltage the difference between the standard voltage and the calibration 

15 voltage. Next, the battery voltage is analyzed as indicated by the decision symbol 380 to 
determine if the voltage is below an operational level. If the voltage is below operational 
level and the previous voltage level obtained from a prior sample is less than or equal to a 
warning level, flien the system is entered into emergency shut down mode as indicated by 
the predefined processing symbol 388. 

20 

With reference to FIG. 7C, as indicated by the decision symbol 394, the current 
real-time voltage is coinpared to S.S volts. If it is greater than 5.5 volts, then the thread 
exits and the software is reset, as indicated in symbol 396. If flie previous voltage level 
is greater tiian the voltage warning level, then the thread enters Phase 1 in FIG. 7E. 

25 

If, however, as indicated in the decision symbol 380, the voltage is not below an 
operational level, processing symbol 384 (FIG. 7B) and processing symbol 398 (FIG. 
7C) indicate that the IR and Battery Detection Thread adjusts the IR emitter power 
corresponding to changes in the operating voltage of the system. With reference to FIG. 
30 7B, if the voltage has decreased since the last battery voltage sample, then the current real 
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time battery voltage is saved to a variable, LastV, representing &e previous sainple 
voltage value, as indicated by processing symbol 390. 

With reference to FIG. 7D ttie emission power level of the JR emitter is then 
5 adjusted to compensate for the decrease in the overall system power changes. The 
decision symbol 392 mdicates that the range of the optical emitter is examined. If the 
range of the optical emitter is selected low and the transmit level is at a minimum, then 
the range of the emitter is set to high and then transmit level is set to a maximum as 
indicated by processing symbols 406 and 408, respectively. 

10 

When the loaded voltage of the system decreases, more power is provided to the 
emitter to compensate for the decrease. This allows the emitter to have a more constant 
range. If the range is not selected as low, as a result of the query indicated by decision 
symbol 392, then the decision symbol 410 indicates that the range is analyzed to 
15 determine if it is low. If the range is low, but the transmit level is not at a minifimim^ then 
the transmit level is altered in processing symbol 412 subtracting 6om the transmit level 
a variable integer, Tstep. 

This allows decreasing adjustment of the transmit level where the range of the 
20 device is aheady toggled low, yet the power of the system has decreased. Decreasing the 
transmit level decreases the required power of the emitter. If the query in decision step 
410 indicates that the range is not set low, then decision symbol 414 determines if the 
transmit level is at a minimimi high. If it is, tiien the transmit level is alt^ed in 
processmg symbol 416 by subtracting from the transmit level a variable integer, Tstep. 

25 

If the overall system voltage has mcreased smce the last battery voltage sample, 
then decision symbol 398 (FIG. 7C)indicates an adjustment for an increase in overall 
system operating voltage. With reference to FIG. 7D, processing symbol 418 examines 
the cxurent real time operating voltage to determine if the voltage is greater than the last 
30 voltage reading. If the current voltage is greater than the last voltage reading, then 
decision symbol 420 queries the range and the transmit level of the IR emitter. If the 
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range is selected as high and the transmit level is at a maYim^iyn ^ then the range is set to 
low in processing symbol 422 and the transmit level is set to low. If the transmit level is 
not at a maximum, then flie transmit level is examined to see if it is less than tiie 
maximnm transmit level subtracting an integer variable, TStep. If the transmit level is 
5 capable of being adjusted from the query in decision step 424, then the processing step 
428 (FIG, 7F) indicates that the IR transmit level is adjusted, providing the sensor more 
current This is accomplished by increasing tiie transmit level by a variable integer, 
Tstep. 

10 Once the IR emitter transmit level is adjusted for either an increase or a decrease 

in overall system power, the IR and Battery Detection Thread 366, as indicated in BIG. 
7E, examines the overall system voltage reading in decision symbol 400. 

If the voltage level is below the warning level, then a flag is set in processing 
15 symbol 402 that indicates that the voltage level is below the warning level. With 
reference to FIG. 7F, if the voltage level is greater than the warning level, then the 
warning count is set to zero in processing symbol 430, and the voltage low warning flag 
is cleared in processing symbol 432. The unloaded battery voltage is compared to the 
battery high level in decision symbol 460. If the voltage is high an error is indicated in 
20 processmg symbol 462. Then the previous voltage variable is set to the current voltage 
value in processing symbol 438. 

Witibi reference to FIG. 7E, at processmg symbol 404, if the warning count 
indicates a 20-second low voltage, then the low battery warning flag is set. In processing 
25 symbol 432, flie current real time voltage reading of the overall system is saved to the 
variable indicating the previous voltage reading to be used by the next iteration of the IR 
and Battery Detection Thread 366. Phase one begins at processing symbol 438. 

The starting point for phase one is indicated by processing symbol 438 in FIG. 
30 7E. Phase one (1) of the Analog Conditioning and Error Checking Thread 366 is 
responsible for determining if the IR sample received from the IR and Battery Sampling 
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Routine is wifhin believable limits. In addition, phase one examines the IR electronics to 
detemiine if the electronics are in working order. 

The IR reflection sample received in the IR and Battery Sampling Routine 326 is 
5 saved to a time-sequenced array in processing step 438. The decision symbol 440 
indicates that the array is examined, comparing it to believable values. With reference to 
FIG. 7G, if the values are valid, then an error is not indicated and the IR Sample Lost 
Error flag is reset in processing symbol 442. If the values do not appear to be valid, then 
the Error flag is set in processing symbol 444. 

10 

In processing symbol 446, a test is performed on the overall system voltage to 
determine if the collar that contains the electronics 114 (FIG. 1) is working properly. 
The decision step 448 indicates that the voltage is examined comparing the normal 
operating voltage of the overall system to the voltage value at a time when the IR 

IS electronics are operating (this value is indicated as loaded voltage). If the loaded voltage 
is greater than the normal operating voltage, then the difference between the two voltages 
is examined as indicated by decision symbol 450. If the difference between the two 
voltages is greater than or equal to 71 mV, then the comparison indicates that the IR 
electronics (the collar) are in workmg order, and the flag indicating an error is cleared in 

20 processing symbol 454. If the difference is less than 71 mV, then the flag is set in 
processing symbol 456 to indicate an error. 

If the symbol 448 indicates that the loaded voltage is less than the normal 
operating voltage, this indicates that the IR electronics are not working properly. 
25 Consequently, the error flag is set in processing step 452. 

Phase two begins at processing symbol 458. Phase two of the Analog 
Conditioning and Error Checking Thread 366 examines the IR ambient sample received 
in the IR and Battery Sampling Routine 326 (FIG. 6) indicated by processing symbol 360 
30 (FIG. 6B). The ambient sample is an IR sample by the detector 116 (FIG. 1) when the 
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emitter 118 (FIG. 1) is not active; therefore, flie ambient sample is an IR reacUng that 
indicates the normal environmental IR present 

With reference to FIG. 7G, as indicated by decision symbol 462, the ambient 
5 sample is saved to a tune-sequenced array, and the query determines whether the IR 
ambient sample is within believable limits. 

If the value is not within believable limits, the detection flag is cleared in 
processing symbol 466 and an error is set that indicates that the DR. ambient sample is not 

10 valid The flag indicating that the decision has been made is set iu processing symbol 
486. If the IR ambient sample is within believable limits, then an error flag is reset to 
indicate no error in processing symbol 464. Next, the decision symbol 468 indicates a 
query to determine if the last pulse cycle resulted in activation of the fluid dispensing 
device. If the last cycle resulted in the activation of the fluid dispensing device, then tiie 

15 IR dynamic base is set to the sum of the ambient value and the reference base decreased 
by the 'Tiand block level" as indicated in processing symbol 472. The *liand block level" 
a constant value subtracted in order to account for errors in invalid detection readings. 

With reference to FIG. 71, if the difiference between the reflection sample and the 
20 IR dynamic base is greater tan the detection value, the detection flag is then set in 
processing symbol 490. Because the IR dynamic base does not include the previously 
reflected IR from the user's hands, the difiference between the IR dynamic base and the 
reflection sample will indicate detection. If the decision symbol 476 query does not 
indicate that an object is present, then the detection flag is cleared as indicated by 
25 processing symbol 478. Lastly, the IR decision made flag is set in processing symbol 
486. 

If the last cycle did not result in the activation of the fluid dispensing device in 
decision symbol 468 (FIG. 7G), then the IR dynamic base is set equal to the sum of the 
30 ambient value and the reference base increased by the '"Body Level" as indicated in 
processing symbol 474. The 'TBody Level*' is a constant based on the current range 
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setting of the detector, requiring more energy to turn on the feucet As indicated by the 
decision symbol 480, if the diflB^ence between the reflected sanq)le obtained in the IR 
and Battery Sampling Routine 326 and the dynamic base is greater than or equal to a 
detection value, then the detection flag is set in processing symbol 484. Thereafter, the 
IR decision made flag is set in processing symbol 386. It on Ihe oflier hand, the 
difference is not greater than or equal to the detection value, tiien the detection flag is 
cleared in processing symbol 482, and the IR decision made flag is set as indicated by 
processing symbol 486. 

Phase three of the Analog Conditioning and Error Checking 366 releases thread 
control and resets the phase of the thread to zero. This is indicated in processmg step 
488. The thread then returns as indicated by temiination symbol 492. 

The overall firmware operation 202 m BIG. 5 continues at processing symbol 252 
in FIG. 5B. In processing symbol 252, the DIP switches of the system are read to ensure 
proper operation modes. 

Processing symbol 254 mdicates a call to the Motion Detection Thread 501, the 
flowchart for which is illustrated in HG. 8A*^D. The Motion Detection Thread 501 is 
that fimctional part of the software that determines if the fluid dispensing device should 
remain activated in light of motion detected by the emitter/detector pair. 

With Inference to FIG. 8A, the Motion Detection Thread 501 begins at procsessmg 
symbol 504 at phase one. As mdicated by processing symbol 504, Phase 1 of the Motion 
Detection Thread 501 is executed when the device is currentiy dispensmg fluid. The 
decision symbol 506 queries the IR Detection Flag to determine if an object was detected 
by the IR and Battery Sampling Routine 326. If the Detection Flag is set, the counter for 
water flow timeout is set to zero (0) as mdicated in processing symbol 500. 

The decision symbol 512 determines whether the water has been runnmg for more 
than forty-five (45) seconds, which is a timeout Umit If the water has been running more 
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than 45 seconds, then an over limit flag is set indicating that the water running limit is 
reached, and the flag indicating that the water is running is reset or cleared as indicated 
by processing symbol 516. The solenoid is pulsed to close the valve in processing 
symbol 518. 

If the water has not been numing for more than forty-five seconds in processing 
symbol 512, then the 45 second timeout is checked in 522, and the last reflected IR 
sample is retrieved in 524. The last reflected sample obtained in the IR and Battery 
Sampling Routine 326 is then compared to the current IR sample in decision symbol 526. 
If the current sample exceeds the previous sample, then the last IR sample is subtracted 
from the current IR sample. If the difference is less than a predetermined value that 
mdicates a motion threshold in decision symbol 542, then a flag indicating that no motion 
was detected is incremented as indicated in processing symbol 544. If the difference is 
not less that the predetermined value, then a flag indicating that motion was not detected 
is reset or cleared as indicated in processing symbol 546. 

With ref^race to FIG 8B, if in decision symbol 526 Ae query indicates that the 
current sample does not exceed the previous sample, then the current IR sample is 
subtracted from the last IR sample as indicated by the decision symbol 538. If the 
diff^^ce is less than a predetermined value fliat indicates a motion detection threshold, 
then a flag is incremented as indicated in processing symbol 548 (FIG. 8A) that indicates 
that no motion was detected. If flie difference is not less that the predetermined value, 
then the flag indicating no motion detected is cleared as indicated in processing symbol 
540 (FIG. 8B). 

With reference to FIG. 8C, decision symbol 550 indicates that, if the flag 
indicating that no motion is detected exceed the motion timeout value, then the Motion 
Detection Thread 500 returns as indicated by the tenninating symbol 554 in FIG. 8C. In 
other words, no motion is detected, and it has exceeded timeout, then the Motion 
Detection Thread 500 terminates until the water is activated again. With respect to FIG. 
8D, if the timeout duration has not been surpassed, then the Motion Detection Thread 500 
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proceeds by resetting the flag indicating no motion and the counter in processing symbol 
556. The Water Running indicator is cleared in processing symbol 558, and a separate 
process as indicated by the process call 560 is initiated that pulses the solenoid to close 
the valve. 

5 

Phase four begins at processing symbol 562. If the IR Detection Flag is clear (no 
detection of a user's hands) by the query indicated in decision symbol 564, then the 
thread returns to the water off phase zero (0) as indicated in processmg symbol 552 (FIG. 
8C). 

10 

With reference to FIG. 8D, if a user's hands were detected in the decision symbol 
564, then the previous reflected IR sample is retrieved in processing symbol 566. The 
current reflected IR sample is compared to the previous reflected IR sample in decision 
symbol 568. If the current sample is greater tiian the previous sample in decision symbol 

15 568, then the difference in the current IR sample and the previous IR sample is examined 
to determine if it exceeds the IR motion change threshold in decision symbol 570. If it 
does not meet or exceed the threshold, then the thread returns in the terminator symbol 
554 (FIG. 8E). In other words, a drop in IR will not turn on the water. If it does indicate 
a motion change in decision symbol 570, flien water off phase zero (0) is initiated in 

20 processing symbol 572. 

If at the decision symbol 506 in FIG. 8 A, it is determined that the IR Detection 
Flag is not set, then there has been no motion detected and the flitid is currentiy being 
dispensed from the device. Wifli respect to FIG. 8B, if the duration of the fluid 
25 dispensing has exceeded a timeout threshold from the query in decision symbol 528, then 
the No Motion Detection flag is incremented in processing symbol 530 and the Water 
Running flag is cleared in processing step 532. The solenoid is then pidsed to close the 
valve in the predefined process' as indicated in 534, and the Water Off phase is set to zero 
(0) in process symbol 536. 

30 
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Thread control is then returned to &e overall firmware structure 202 as illustrated 
in FIG. 5. In FIG. SC, decision symbol 258 indicates that the firmware determines if 
there are any pending events. If there are pending events then the main thread timer is 
queried to determine if a cycle has e?q)ired. If the cycle time has expired, fte cycle 
S begins again at processing step 240 (FIG. 5B) where the microcontroller is deactivated 
until the next cycle is initiated on tiie 250 millisecond interval. 

If the cycle time has not expired, then the optical sensor looks for the Attention 
signal initiated by the handheld computer in processing symbol 262. The Attention 
signal is emitted by the handheld computer as indicated in the Send Status function 178 
in processing step 182 (FIG. 4), If the handheld computer has requested connected mode 
of the fluid dispensing device and the Attention signal is a valid signal, then the decision 
symbol 264 indicates that a transmit status response is sent to the handheld computer in 
the subsequent predefined process step 266. Once the Status Response is transmitted, 
then the handheld computer and the fluid dispensing device enter connected mode as 
indicated in predefined processing symbol 268. The firmware remains m connected 
mode until a conounand is transmitted or a timeout occurs in processing symbol 268. If an 
End command is communicated by the handheld computer or a timeout occurs, the 
variables for the thread events are reset and the DIP switches are queried as indicated in 
processing symbol 270. 

The TBM interrupts are re-enabled in processing symbol 272 allowing the pulse 
cycle to continue, then the operation of the IR electronics are examined as indicated in 
the decision symbol 274. If the IR electronics have been vaaplugged then the system is 
25 configured to do reflection calibration in one (1) second in processing step 276. In 
decision symbol 278, the IR electronics are then tested to determine if the devices are 
unplugged, if thKe is a battery warning, or if ttiere exist any other errors. If each of die 
queries returns a negative response, then this error data is saved in processing symbol 
282. 

30 
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Tlie error indications are saved into a report for user acc^ibilify in processing 
symbol 284. The decision symbol 288 queries the error bits to determine if the errors 
changed fiom the last iteration of the firmware structure 202. If the error has changed, 
then the previous error is saved in processing symbol 290. With reference to FIG. 5D, 
5 the TBM interrupts are re-enabled in processing symbol 292, and error messages are 
transmitted to the handheld computer in predefined process symbol 294. 

The decision symbol 296 indicates a query of the IR electronics. If the electronics 
are working properly, then the pulse cycle is reinitiated in FIG, SB at processing symbol 
10 240. 

If the electronics are not working properly, then the system is placed into low 
power IR electronics unplugged Mode in predefined processing symbol 300. The system 
remains in low power mode as indicated by the decision symbol 302 until the electronics 

15 are reactivated Once the IR electronics begin working properly, processing step 308 
indicates that the prq)aration is taken for the recycling of the IR and Battery Sampling. 
Thread control is reset in processing symbol 310. If the calibmtion flag is set, then the 
TBM Interrupt Service Routine is initiated in processing symbol 314. If Factory 
calibration is required as determined in decision step 316, tfien the predefined Factory 

20 Calibmtion Thread is run as indicated by the predefined Factory Calibration symbol 318. 
The system then holds until reset in process symbol 320 at which time the Firmware 
structure begins anew at decision symbol 208 in FIG. 5A. 

If Factory Calibration is not indicated in the decision symbol 316, then the 
25 predefined Dynamic Calibration is run as indicated in the predefined processing symbol 
322. To reinitiate the threads, the TBM interrupts are reset in processing symbol 324, 
and a pulse cycle begins at processing symbol 240 where the microcontroller is 
deactivated until a cycle is mitiated by the TBM. 

30 If Factory Calibration is not indicated, then the Dynamic Calibration Thread 598 

as illustrated in FIG. 9 is run from the firmware overview structure 202 at processing 
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symbol 322. The Dynamic Calibration Thread 598 is executed both initially when the 
jBrmware is first powered up and periodically to adjust the IR hardware components as 
required by environment and system changes. 



S The Dynamic Calibration Thread 598 starts at the input symbol 600 in FIG. 9A. 

The calibration begins by initializing required variables, setting the initial emitter 
selection to low, and setting the IR LED current to a nominal value ( the transmit level) 
as mdicated m processing symbol 602. Tbie microcontroller is deactivated for the 
duration of a regular 250 milliseconds TBM cycle in processing step 604. The Interrupt 
10 Driven IR and Battery Sampling Routine 326 (FIG. 6) is called in order to obtain initial 
samples of the battery voltage as indicated in processing step 330 (FIG. 6A), the 
reflected IR as indicated in processing step 356 (FIG. 6B), and the ambient IR as 
indicated in processing step 360 (FIG. 6B). 

15 Processing symbol 608 indicates that the Dynamic Calibration Thread 598 sets 

the current input to the IR LED based on the battery voltage sample obtained from the IR 
and Battery Sampling Routine 326 (FIG. 6). The current range is set to high if the 
compensated battery voltage is less than the switchover point in processing symbol 610, 
and processing symbol 612 adjusts the IR LED current if it exceeds an operational limit 

20 that afiEects performance. 

Decision symbol 614 begins the actual calibration of the IR LED and the optical 
sensor. If tiie transmit level (or initially tiie nominal IR LED current) is less than a 
minimum transmit value in order for the IR emitter to reach an effective range, then the 
25 microcontroller is deactivated until the next TBM cycle in processing symbol 616 in 
FIG. 9B, and the Interrupt Driven IR and Battery Sampling Routine 326 (FIG. 6) is run 
in processing symbol 618 in FIG. 9D. 



With reference to FIG 9D, in the decision symbol 620, the reflected IR including 
30 the ambient sample is compared to the ambient level when the IR LED has not emitted a 
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pulse. This is in contrast to the initial setting that simply used reference values according 
to the standard LED based on the battery voltage reading. 

With reference to FIG. 9C, if the sum of the reflected IR and the ambient level is 
5 greater than the ambient level when the IR LED has not emitter a pulse, then the reflected 
IR is the Reference Base Value as indicated in processing symbol 622. If the IR level, 
which is defined as the sum of the Reference Base, the Reflected IR, and the Ambient IR, 
is below a detectable saturation limit in decision symbol 624, then the current input to the 
IR LED is examined in decision symbol 626. 

10 

If the current input to the IR LED is below the low limit, then the transmit level is 
set to a maxifmim value in processing step 634, and an error bit is set that indicates that 
the emitter cannot be adjusted down any &rther in processing symbol 636. The battery 
voltage is then equalized in processing symbol 630 in order to prevent battery error, and 
15 the Dynamic Calibration Thread returns as indicated by the terminator symbol 646, with 
OTors. If the current input to the IR LED is not below the low limit, then the battery 
voltage is then equalized in processing symbol 630 in order to prevent batt^ error, and 
the thread returns as indicated by the terminator symbol 646, without erroris. 

20 If the sum of the reflected IR and die ambient level is not greater dian the ambient 

level when the IR LED has not emitted a pulse in decision symbol 620 (FIG- 9D), tiien 
the difference between the Ambient IR and the Reflected IR (including the Ambient IR) 
is examined in decision symbol 638 in HG. 9D. If the difference is less than the 
expected noise level, thm the Reference Base is set to zero (0). If the difference is not 

25 less than the expected noise level, then an error bit is set in processing symbol 642, and 
the IR level is examined in decision symbol 624. If it is below a detectable limit, then the 
process provides an error before exiting if the IR LED current was below a low limit If 
it was not below a low limit, it simply exits. 
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COMMUNICATION PROTOCOL 

Data communication between the optical inter&ce ports of the handheld con^puter 
104 (FIG. 1) and the fhiid dispensing device 106 (FIG. 1) is now described. 
5 Communication between the devices is implemented as Broadcast Mode or Ck>nnected 
Mode. 

Broadcast Mode 

10 The Broadcast mode is employed when flie receiving control logic of a preferred 

embodiment discovers errors including, but not limited to, a malfunctioning solenoid, a 
low battery, or a reflected signal that is out of range at calibration. When such an error is 
detected during the normal operations of the firmware of the fluid dispensing device, a 
signal is emitted from an IR emitter 118 (FIG. 1) of the fluid dispensing device. 

15 

The signal emitted has the following format: 

ERRSSSSSSSE(CS)(LF). 

20 The emission is sent once per second. The specification of the signal is illustrated m 
FIG. 10. The first three bytes indicate that the signal is a Broadcast signal including an 
ASCn *TERR'* 650. The next byte 656 includes an 8-bit serial number identifying the unit 
that has detected an rax>r. Byte 658 indicates the type of error that has been detected. 
The following table describes the types of raors and the corresponding byte indicators: 

25 



BIT 


ERROR TYPE 


BitO 


Solenoid Open 

Circuit or Unplugged 


Bit 2 


Solenoid load too 
heavy 


Bits 


Ambient IR level out 
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ofRan^ 


Bit 4 


Reflected IR out of 
range at Calibration 


Bits 


Low Battery Warning 


Bit 6 


Collar Unplugged 



TABLEl 



Hie checksum byte 660 is a modulo 256 checksum inverted, and the last byte is an ASCII 
5 linefeed 662 to indicate termination of the signal. 

The control logic of the handheld computer processes a discovered error(s) and 
communicates the error(s) to the handheld computer. The Broadcast Communication 
Process is shown m FIG. 22 and is designated generally througjiout with reference 
10 numeral 882. 

Decision symbol 884 detennmes if an error has been detected within the fluid- 
dispensing device. Within the system, a timer is set, for example to broadcast error 
messages every five (5) pulse cycles. Therefore, in decision symbol 886 it is deteraiined 
15 whether it is time to send out a Broadcast Signal. If it is not, then tiie fluid dispensing 
device continues with normal operation in terminating symbol 892. 

If it is time to transmit a Broadcast Signal, then the error data is sent in processing 
symbol 888. 

20 

The handheld computer executes a scanning function that can be initiated by a 
user. FIG. 3 represents the communication function of the handheld computer. The 
optical interface port is initialized 148, and the IR-State variable is set indicating that the 
port is opra in 150. The gCommand variable of the switch symbol 152 indicates that a 
25 user has selected the scan functionality. The scan function searches for a Broadcast 
signal of the type described. 
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Once detected," the signal is parsed and the infonnation is stored on the handheld 
computer. This infonnation is Ihen readily available to Ihe user for maintenance 
5 purposes. 

Connected Mode 

The Connected Mode is mitiated by tibe handheld computer when a user selects a 
10 functionality that requires data to be sent to the fluid dispensing device. As described, 
infra, an Attention Signal is emitted from the optical interface port of the handheld 
computer. 

The Attention Signal specification is illustrated m FIG, 11. The Attention Signal 
15 is defined as a hexadecimal *TF' 664. The 'TF" is foUowed by a four (4) byte computer 
software identification ASCH code 668. The four-byte code 668 mcludes 4 ASCn 
characters identifying die company and product. The last byte 670 indicates an Origmal 
Equipment Manufacturing (OEM) code. 

20 The "FF" 664 is sent continuously for 300 milliseconds (approxhnately 50 

milliseconds longer than a normal fluid dispensing device pulse cycle). This aUows the 
fluid dispensing device the opportunity to detect the Attmtion Signal if ttie Attention 
Signal is initially sent during a 250 millisecond cycle. 

25 The fluid dispensing device responds within 39 mimseconds (14 mill^ 

the water is ofi). If there is no response fix)m the fluid dispensing device, then the 
Attention Signal is sent repeatedly at a predetennined interval untU a response is detected 
by the handheld device. 

30 The Attention Signal response sent by the fluid dispensing device includes status 

information that is described with reference to FIG. 12. The initial ASCfl "STA" byte 
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672 indicates that the fluid dispensing device is responding to the Attention Signal. The 
8-byte serial number 674 indicates the serial number of the device responding to the 
Attention Signal. This 8-byte word is displayed on the handheld computer as a 
hexadecimal number. The 2-byte software version 676 indicates to the handheld device 

5 the version of the firmware used on the fluid dispensing device. The next 2-byte PCB 
version 678 indicates the board revision number and the part number of the board. The 
one-byte Engineering Change Order C*ECO'*) level indicates previous maintenance order. 
The one-byte TR input level 681 identifies the IR sensitivity. The one-byte IR reference 
base reading provides an eight-bit reading. The one-byte IR ambient reading 683 is 

10 provided. The one-byte IR battery voltages 684 and 686 provide a normal operating 
battery voltage and a battery voltage at the end of a solenoid pulse, respectively. The 
following two bytes provide an hour count 688 for time purposes. The IR transmit 
calibration level byte 690 provides a voltage output value of the emitter, and the next byte 
provides a one-byte voltage level 692 of the voltage being used. The next byte is the 

IS battery calibration level 694 indicating a voltage reading of the battery at calibration. A 
one-byte solenoid count 696 and a two-byte solenoid lO's count 698 follow. The dip 
switch settings are indicated in the next byte 670. Hie following table describes the bit 
numbers with corresponding definitions: 



BIT 


DESCRIPTION 


B7 


DIP Switch 5 (water saver) 


B6 


DIP Switch 1 (Range 1) 


B5 


DIP Switch 2 (Range 2) 


B4 


DIP Switch 3 (Scrub Mode, 
60 second off delay) 


B3 


DIP Switch 4 (Meter Mode) 


B2 


Unused extra input jumper 


Bl 


Not used 


BO 


Not used 



20 

TABLE 2 
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The virtual DIP switch settings are provided in byte 672 and are defined the same 
as the manual DIP switch settings except BO is defined as 'Use All Virtual Settings." 
Range ofi&et 674, delay in seconds 676, past error bits 678, and current error bits 680 
S provide additional information describing the current fluid dispensing device parameters. 
Status of &e fluid dispensing device is given in the n^ byte 682 and the bits are defined 
as follows: 



BIT 


DEFINITION 


B4 


PROGRAMMING 
ERROR, NUMBER OF 
BYTES SPECIFIED • 


B2 


PROGRAMMING 
ERROR, ADDRESS 
SPECIFIED 


Bl 


FLASH PROGRAM 
OPERATION NOT 
VERIFIED 


BO 


LAST COMMAND 
CHECKSUM FAILED 



10 TABLES 

A one-byte spare is provided 684, and the transmission is terminated with a checksum 
686, and a linefeed 688. 

15 Once connected mode is established, the handheld computer has several 

fimctions. The handheld computer can send a status request, send a set conunand, or 
send a program command. 

A status request bom the handheld computer is responded to by the fluid 
20 dispensing device indicating that information that is sent when Connected Mode is 
accomplished. The status request flowchart in FIG. 4 illustrates the soflware flow on the 
handheld compute when a Status command is requested. Processing symbol 184 
indicates the transmission of a Status command, and the specification for the Status 
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conunand is illustrated in FIG. 13. A status command begins with and ASCII ''SST' 
690. A one-byte spare 692 is followed by a checksum 694 and an ASCH linefeed 696 fox 
termination. 

5 A Set command allows a user of ttie handheld device to reprogram various 

electronics of the fluid dispensing device, including but not limited to the DIP switches 
(i.e. virtual DIP switch settings), range offiet, delay in seconds, sound, hardware settings, 
and connected mode timeout FIG. 14 illustrates a string transmitted by the handheld 
computer to accomplish a Set command The ASCII "SET' string 700 is sent in the least 
10 significant byte. Following the "SET' string is an eight-byte serial number 702 
indicating the handheld computer that is initiating the "SET' command. The one-byte 
virtual DIP switch settings 704 are described by the following table: 



BIT 


DESCRIPTION 


B7 


DIP Switch S (water sav&i) 


B6 


DIP Switch 1 (Range 1) 


B5 


DIP Switch 2 (Range 2) 


B4 


DIP Switch 3 (Scrub Mode, 
60 second off delay) 


B3 


DIP Switch 4 (Meter Mode) 


B2 


Unused extra iiq)ut jiimpa: 


Bl 


Not used 


BO 


All Virtual Settings 



15 TABLE 4 

The enutter range of&et is provided in the next byte 704, and a delay is provided in the 
next byte 708. The sound can be turned on/off witibi the sound byte 710. BO indicates 
sound off. Byte 712 provides the IR ambient level reading. The user can reset hardware 
20 settings in the following byte 714 including BO that resets die main board and Bl that 
indicates a soft reset. Resetting the .main board includes the fliiid dispensing device 
waiting 10 seconds, exiting Coimected Mode, then resetting all the variables. A Soft 
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Reset includes waiting 10 seconds, exiting Connected Mode, retaining virtual settings, 
and re-calibration. The next byte 716 allows the Connected Mode timeout to be changed 
in the range of 0-255 seconds. Finally, a spare byte 718, a checksum byte 720 and an 
ASCn Unefeed 722 terminates the "SET ' command. 

5 

A Program Command allows a handheld computer user to reprogram the fluid 
dispensing device. The Program Coomiand Specification is illustrated in FIG. 15. 
ASCn 'TRG" 724 initiates a Program Command, A four-byte serial number 726 follows 
indicating the identification of the handheld computer. The next two bytes 728 provide 

10 the target address of the fluid dispensing device. Typically, the target address includes 
the software type, the PCS code and the address returned from an "STA" Command. 
The number of bytes making up the new code is transmitted in one byte 730, and the code 
itself is transmitted in the following 128 bytes 732. If the code exceeds the 128 byte 
limit, then multiple "TRG" Conmiands can be sent from the handheld computer in order 

15 to transmit the entire piece of code. A checksum 734 and an ASCII linefeed 736 
terminate the signal. 

The handheld computer sends an End Command as illustrated in FIG. 16 in order 
to terminate the Connected Mode between the handheld computer and the fluid 
20 dispensmg device. An ASCII 'ISND" string 738 initiates tiie End Command. It. is 
followed by a one-byte spare 740 and a checksum 742. The End Command is terminated 
by an ASCII linefeed 744. 

GRAPHICAL USER INTERFACE OF HANDHELD COMPUTER 

25 

The Gmphical User hiter&ce (GUI) of fbe handheld computer is now described 
with reference to FIG. 17, The handheld computer 750 generally includes a casing 756 
having a monitor 754, an optical interfece port 752, and a power button 756. The 
monitor can be a touch-screen or any other type of monitor known in the art. 

30 
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The system provides the user with several options inchiding 1) **Get Faucet Data" 
758, 2) "Adjust Faucet" 760, 3) "Scan for Problems" 761, 4) 'Infoimation" 762, 5) 
'Troubleshoot" 764, and 6) 'THelp" 766. Of flie six (6) options provided, options 1) 
through 3) require communication with the fluid dispensing device. 

5 

Hie "Get Faucet Data" option 758 retrieves and stores fluid dispensing device 
information. Rjetrieval of the fluid dispensing device data is accomplished by executing 
the SST command of the handheld computer. As described, the handheld conq)uter emits 
an Attention Signal. When the fluid dispensing device detects the Attention Signal the 
10 handheld compute and the fluid dispensing device enter Connected Mode, The fluid 
dispensing device then transmits a set of information describing various parameters of the 
fluid dispensing device. 

Once the data is retrieved, the data is stored in the handheld computer for user 
IS accessibility. FIG. 18 illustrates the GUI interface that is displayed once the data is 
received firom tibie fluid disp^ing device. The fluid dispensing device data can be 
reviewed by pressing the five tabs on the screen including Power 775, Settings 776, 
Usage 778, Time 780, and Miscellaneous 782. 

20 The Power tab 775 contains data relating to the power operating parameters of the 

fluid dispensing device. These parameters include normal operating voltage, loaded 
voltage, time in use and battery replacement date. 

The Settings tab 776 contains data on the various system settings accessible to the 
25 user. These settings include, but are not limited to, operating mode, range setting, range 
of&et, delay setting and virtual settings. The fectory default operating mode is the 
normal motion detecting mode where water flows within 250 milliseconds after 
activating sensor and stays on as long as motion is detected. The maximum on time in 
this mode is 45 seconds. Additional modes include scrub mode where water continues to 
30 flow for sixty (60) seconds after deactivation of the sensor, metered mode having a 10- 
second flow time from first hand detection, and water saver mode having a 5-second 
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maxiimim on time starting fix>m first hand detection and fast tumofif when hands are 
removed. 

The Usage tab 778 provides information such as die number of uses, uses per day 
5 and uses per month. The Time tab inchides the time of the scan, the date of the scan and 
the total on-time for the faucet Finally, the Miscellaneous tab 782 includes current 
errors, past errors, software version, PCB number and engineering change level. 

Additional pushbuttons Help 784, Review Data 786, Next 788, and OK 790 
10 provide additional functionality. Review Data 186, when selected, displays data jfrom the 
fluid dispensing device. Next 780, when selected, performs another "Get Faucet Data" 
function on a fluid dispensing device. 

The ''Adjust Faucet" option 760 (FIG. 17) allows a user to edit &e parameters of 
IS the fluid dispensing device and download parameter changes to the device, itself. 
Selecting the "Adjust Faucef ' option 760 bom the Commander menu in FIG. 17 displays 
the GUI illustrated in FIG. 19. This GUI is a form having numerous areas in which the 
user can enter information about the parameters of the fluid dispensing device. The user 
can modify the ••Range" 792 of tiie emitter by selecting one of the checkboxes •'Shortf* 
20 810, ••Normal" 814,;^Far'' 812 or "Maximmn" 816. 

The user can also modify the •'Mode" 794 in which the fluid disp^ing device is 
operating. The user can place die device in ••Normal" mode 802, ••Scrub" mode 806, 
••Metered" mode 804 or •'Water Saver'* mode 808 by selecting the corresponding 
25 checkbox. 

The range slider 818 allows the user to add or subtract 2 inches from the optics 
range. Initially, the user mxist calibrate the faucet to determine the current range length. 
The slider can then be used to adjust the current range ±2 inches. 

30 
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In addition, the user can change the **Delay Time" 796 of the opeiadng mode 
selected. The user can enter a delay time ranging from zero to 180 seconds by entering 
the time in the text field 792. Also, the user can elect to 'Tum off Beeps" by selecting 
the checkbox 798 or '*Reset Faucef ' by selecting the checkbox 800. 

5 

Once edits have been completed, the user selects the "SET' piishbutton 820. As 
described, infira, with reference to FIG, 14, the Set Command is initiated by transmitting 
the "SET' signal after obtaining Connected Mode. The "SET* stream is sent to the fluid 
dispensing device, and the requested changes to the device parameters are updated. 

10 

The "Scan For Problems" option 761 (FIG. 17) allows a user to scan a set of fluid 
dispensing device, searching for a signal from a device that has entered Broadcast Mode. 
This allows the handheld device to determine from the Broadcast Mode signal devices 
that are currently in need of service. Selecting Ae "Scan For Problems*' option 761 from 
IS the Coimnander menu in FIG. 17 dispkys the GUI illustrated in FIG. 20. As indicated, 
when the GUI illustrated in FIG. 20 is displayed, the "Scanning in Progress" message 
822 is displayed. 

If a fluid dispensing device is m Broadcast Mode, the "Serial Number^ 824 of the 
20 malfunctioning device is displayed In addition, errors associated with the device '"Error 
1" 826, "Error 2" 828 and •*Error 3" 830 are displayed. The user can prevent the 
handheld device from sounding an alarm by selectuig the 'Tum Palm Alarm Ofi" 
checkbox 832. Also, tbe user can select to keep the handheld computer on for as long as 
active scanning is in progress by selecting the "Keep Palm From Turning OflF' checkbox 
25 834. 

The user may continue scanning by selecting the "Continue*' pushbutton 836. 
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EXEMPLARY SYSTEM HARDWAiElE 

Wbile numerous hardware configurations, in addition to those described briefly 
above, may be employed in accordance with the system and method of the preset 
5 invention, refermce will now be made in detail to a second preferred hardware 
configuration and arrangement applicable for use within tiie system of the present 
invention. 

Because the features of the present invention can be shown with block and other 
10 diagrams, conventional electronic elements well known to those skilled in the art, such as 
transistors, amplifiers, resistors, capacitors, programmable processors, logic arrays, 
mmiories and corresponding couplings and connections of such elements are not shown. 
A person skilled in the art could readily understand the block diagrams illustrating 
embodiments of the present invention. The block diagrams show specific details that are 
IS pertinent to the present invention and do not obscure tiie disclosure with details that 
would readily be apparent to tiiose skilled in the art. 

A conventional electronically operated flow control device 94 commonly found in 
the art is shown in Fig. 23. Hie prior art embodiment depicted in Fig. 23 generally 

20 includes a feucet 896, an electronics box 898 for bousing electronic components 899 and 
batteries 901. The electronic coinponents 899 are coipled to a solenoid valve 900, which 
may move between an open position and a closed position in response to instructions 
provided by the electronic box 898. Gena:ally speaking, a wiring harness 904 having 
cables provides power and a communication link between electronics box 898, &ucet 896 

25 and solenoid valve 900. 

As fijrther shown in Fig. 23, &ucet 896 of conventional electronically operated 
flow control device 894 typically includes an ER. emitter 908 and an IR receiver 910 
mounted within a collar 912 (or neck) of faucet 896. The IR emitter 908 and the IR 
30 receiver 910 cooperate to transmit and receive IR signals, which indicate the presence of 
a user's hands or other objects in the vicinity of an aerator 906 When a signal knitted 
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from IR emitter 908 is reflected back and received by TR receiver 910, IR receiver 910 
generates an electrical signal, referred to as a *^flection signal,'* that has a voltage 
corresponding to the signal strragth of the reflected IR signal. The reflection signal is 
coupled through a wire in the wiring harness 904 to electronics box 898. The electronic 
5 components 899 process the reflection signal and send a control signal through wiring 
harness 904 to the solenoid valve 900. When an external object, such as a user's hands, 
moves into the detection range of IR emitter 908 and receiver 910, the signal strength of 
the reflected signal and, therefore, the voltage of the reflection signal should be higher 
than normal. Thus, the electronic components 899 detect the presence of the external 
10 object When the magnitude of the reflection signal is above a particular tiireshold value 
a control signal causes the solenoid valve to open, allowing water to flow in &ucet 896. 
In most conventional flow control devices 894 water flows until a timer expires or imtil 
the reflection signal is again below the threshold value indicating that the external object 
is no longer within the detection range of IR emitter 908 and IR receiver 910. 

15 

An exemplary embodiment of a remotely managed electronically operated 
dispensing apparatus of the present invmtion is shown in Fig. 24, and is designated 
generally throughout by reference numeral 914. Remotely managed electronically 
operated dispensing apparatus 914 preferably includes a dispensing unit, such as a &ucet 

20 916. Faucet 916 preferably includes a collar 912 having an emitter aperture 972 
preferably covered by a signal transmissive lens, and a receiver aperture 966, which 
permit signals, such as, but not limited to, IR signals to exit and enter collar 912. 
Remotely managed automatic dispensing apparatus 914 further includes a control module 
926, a latching solenoid valve 930 that opens and closes in response to signals provided 

25 by control module 926. In the preferred embodiment, control module 926 is contained in 
an enclosure that incorporates an anti-vandalism bracket (not shown). Remotely 
managed automatic dispensing apparatus 914 may also include one or more flexible 
sheaths (not shown) for protecting and positioning the electrical cables 934, which 
provide a communication link between a sensor module 958 (Fig, 27) positioned within 

30 collar 912 of faucet 916 and control module 926, and between control module 926 and 
latching solenoid valve 930. 
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The primary purposes of the flexible sheathes are to protect tiie electrical wiring 
and to position the electrical wiring with respect to control module 926 and latching 
solenoid valve 930 such that flexible sheathes form one or more drip loops which are 
S designed to capture any wat^ inadvertently running down die electrical wiring firom a 
leak in faucet 916, the sink, or otherwise. A primary objective of the drip loops is to 
prevent water from entering the cables and reaching the electronics within the control 
module 926 and/or the latching solenoid valve 930. Gravitational forces act on any water 
collected in the drip loops thereby preventing tiiat water from contacting the connectors 
10 or other electronic circuitry within or adjacent to control module 926 and latohing 
solenoid valve 930. 

Remotely managed automatic dispensing apparatus 914 also preferably includes a 
sensor board or sensor module 958 (Fig, 27) that is particularly well suited for being 
15 retrofit within collar 912. The sensor module 958 may be designed similar to or identical 
to conventional sensor modules employed within conventional flow control devices 894. 
More specifically, the sensor module 958 may be constructed and arranged so that it may 
be installed in a coUar having only two apertures, which is typical for conventional flow 
control devices 894. 

20 

As will be described in greater detail below, remotely managed automatic 
dispensing apparatus 914 of the present invention is preferably designed to communicate 
with a portable communication device 970. The portable communication device 970, 
which in the preferred embodiment is a reprogrammed personal digital assistant (PDA), 
25 is preferably configured to transmit and receive IR signals for establishing a 
communication link 97 with managed automatic dispensing apparatus 914. 

In addition to an IR emitter 960 and an DR. sensor 962, such as a detection or 
object photo detector, sensor module 958 of the present invention preferably incorporates 
30 a data or communication IR sensor 964 such as another photo detector, for receiving 
communication signals from flie portable conMnunication device 970. In one 
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embodiment, TBi sensor 962 and the communication IR s^isor 964 aie mounted backrto- 
back (not shown) on sensor module 958. Generally speaking, photo detector lens 965 is 
positioned near the front of sensor board 958 for receiving light through receiver q>erture 
966, while communication photo detector lens 968 feces the rear of IR sensor 962. 
S Transparent silicone sealant fill 967 may hold the sensors 962 and 964 securely in aligned 
position. Additional arrangements of IR sensors 962, 964 are possible in other 
embodiments. In particular it is not necessary commumcation IR sensor 964 to receive 
IR signals through the hole 973 of IR sensor 962. For example, a side-by-side 
configuration for sensors 962 and 964 may be employed if desired. Further, in another 
10 embodiment a single sensor, such as IR sensor 962 may serve for detecting reflections 
and for receiving communication signals. 

According to techniques that will be described in more detail below, control 
module 926, sensor module 958 within collar 912, and latching solenoid valve 930 may 
IS be utilized to control operation of &ucet 916 and to provide information pertaining to the 
operational state of &ucet 916. Sinoilarly, these components may be implemented within 
and utilized to control otho: fluid dispensing devices, such as toilets, for example. 

As depicted in Figs. 24 and 31, sensor module 958 is preferably mounted such 
20 that IR emitter 960 is positioned behind and aligned with flie transmit aperture 972 of 
collar 912, while detection photo detector 962 and communication photo detector 964 are 
positioned behind and aligned with tiie receive aperture 966 of collar 912. So arranged, 
the IR signals emitted by IR emitter 960 are transmitted tiiroug^ transmit aperture 972, 
and both the reflected signal from IR emitter 960 and the communication signal emitted 
25 by a portable communication device 970 for controUmg and managing the operation of 
automatic dispensing apparatus 914 are received through receive aperture 966. When 
desired, automatic dispensing apparatus 914 may send infonnation to portable 
communication device 970 (upstream information) through transmit aperture 972. 
Further, automatic dispensing apparatus 914 may receive information from portable 
30 conomunication device 970 (downstream information) through receive aperture 966. 
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Typically, most IR devices, such as tiie IR emitter 960 and IR detectors 962, 964, have an 
integrated lens to focus infrared signals and protect the semiconductor material. 

As shown in Fig. 24, portable communication device 970, such as a Palm Die™ 
S manu&ctured by 3com®, which preferably utilizes the Palm Computing Platform®, for 
example, may be configured to communicate with the remotely managed automatic 
dispensing apparatus 914 of the present invention^ Generally speaking, the portable 
communication device 970 used to communicate with the remotely managed automatic 
dispensing apparatus 914 of the present invention includes an IR emitter and IR sensor 

10 that provide for exchange of data via IR signals passed through apertures 966, 972. It 
will be understood by diose skilled in the art, however, that other devices and particularly 
portable devices, such as personal digital assistants manufactured by other manu&cturers, 
cellular telephones, pagers, portable computers, and the like may be used to communicate 
with the remotely managed automatic dispensing apparatus 914 of the present inventioiL 

IS In addition, communication signals other than IR signals may be used to transfer data 
between any such portable communication device and the remotely managed automatic 
dispensing apparatus 914 of the present invention. It is not necessary that a device 
conununicating with the remotely managed automatic dispensing apparatus 914 be a 
portable device configured for IR communication. For example, one or more wires may 

20 be coupled to the remotely managed dispensing apparatus 914 to serve as a 
communication chaimel for a non-portable communication device. This being said, tiie 
preferred embodiments of ttie present invention will be described hereafter with reference 
to the portable conununication device 970 being the PalmUIe™, but the preferred 
embodiments are in no way intended to be limited only to the above mentioned PDA. 

25 

Generally speaking, the present invention provides an improved maintenance and 
monitoring system for use in commercial facilities such as ofiBce buildings, 
manufacturing plants, warehouses, or the like. For example, public restrooms in an ofBce 
building may benefit firom such a system in that such a system may facilitate the efficient 
30 operation, management and servicing of multiple conventional automatic flow control 
devices throughout the building. More specifically, conventional automatic flow control 
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devices are battery powered and therefore require battery replacement In addition, there 
are typically a plurality of such devices in any given restroom widdn the building. As 
one would expect, the maintenance of such convmtional dispensing devices is both time 
consuming and labor intensive since maintenance personnel have no efBdent way of 

5 determining whether such devices require battery replacement or are otherwise defective. 
As a general rule, manual interaction with each device is required to make these 
determinations. For example, maintenance persomiel position their hands beneath the 
aerator of each conventional automated sink to determine if the faucet is operating 
correctiy. Troubleshooting, however, reqmres the time consuming steps of removing the 

10 cover of electronics box 898, and physically checking and analyzing the circuitry and 
other components thereof. Accordingly, there is a need for an improved maintenance and 
monitoring system for commercial facilities having large numbers of automatic flow 
control devices. 

15 As depicted schematically in Fig. 25, remotely managed automatic dispensing 

apparatus 914 may be a part of a remotely managed automatic dispensing system 974. 
System 974 preferably includes a plurality of remotely managed automatic dispensing 
apparatuses 914i, 9142, —9 914n, each having an associated dispensing unit, such as a 
&ucet 916 or other dispensing device. The portable communication device 970 may 

20 exchange data with each of the automatic dispensing apparatuses via one or more IR 
communication links 971. A site computer 976 capable of coromunicating with portable 
communication device 970 may store information about each of the site's managed 
automatic dispensing devices. Optionally, one of ordinary skill in the art will recognize 
.that system 974 may be monitored and controlled in a network environment In a 

25 preferred embodiment, a remote server 982 may receive data relating to system 974 from 
PCD 970 or a site computer 976 over the Intemet 984 or other network enviromnent via 
any standard network connection. 

System 974 of the present invention largely obviates the need for manual 
30 troubleshooting or servicing of dispensing devices. By implementing the system 974 of 
Fig. 25, maintenance persoimel may enter an area, for example a restroom, containing 
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iiumei:ous remotely managed automatic dispensing apparatuses 914 of the present 
invention, commnnicate vfiftx one or more of the apparatuses 914, and determine which, 
if any, of die apparatuses are defective or otherwise require servicing based on data 
communicated from the one or more ^aratuses 914. Li accordance with tiiie preferred 
S system 974 of the present invention^ a &iling or malfunctioning apparatus 914 may 
automatically discover an operational problem and broadcast an IR data signal indicating 
the nature of the problem. This IR data signal may indicate, for example, the serial 
number, location, and problem, among other things for the defective apparatus 914 in the 
room. Depending upon the nature of the problem associated with one or more of the 

10 apparatuses 914, portable communication device 970 may preferably provide the 
maintenance person with troubleshooting information indicative of the problem. 
Moreover, PCD 970 may also be used to repair defective apparatuses 914. For example, 
when the problem associated with a defective apparatus 914 is software related, PCD 970 
may be used to transmit a software update or otherwise reprogram defective apparatus 

1 S 914 by transmitting software updates via IR. 

In addition, portable communication device 970 preferably includes memory for 
storing information such as die maintenance history and/or software update history of 
each device, or an installation and user's guide that may be used by maintenance 

20 personnel to install and operate new apparatuses 914. The memory may also be used to 
maintain records of data gathered or entered for each apparatus 914, by s^al number. 
More preferably, portable communication device 970 may be used to transmit, to one or 
more' apparatuses 914, commands for adjusting apparatus parameters such as IR range, 
and/or update the software of a given apparatus 914, thus largely eliminating the need for 

25 maintenance personnel to open the electronics box 926 and physically access one or more 
of the apparatus boards. Such commands may be received by IR sensor 964 and 
processed by signal processor 1006 (Fig. 27). 

Information collected by portable communication device 970 may also be 
30 transferred to a site computer 976 for updating device records in stored memory of the 
site computer. In addition, any information transmitted by any apparatus 914 to portable 
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comnwinicatioii device 970 may be sent to a web server 982 via the Internet 984 where 
the information may be logged and stored in a relational database, such as Miax)Soft 
Access, for device fault analysis or other research. Additionally, web server 982 may 
generate and deliver responses to trouble reports received from portable communication 
5 device 970 and system updates to site computer 976 via the Internet 984. 

Figs. 26a-26f depict various display screens, as viewed on portable 
communication device 970, that may be used in comiection with system 974 of the 
present invention. For example, a control panel screm 986 displays, on portable 

10 communication device 970, a menu of selectable items for the managed automatic 
dispensing apparatus 914. By way of example, but not limitation, a user may select 
•Information" from screen 986 and obtain information about a faucet as viewed on 
Information screen 988. Adjust screen 989 provides inputs for adjusting feucet 
parameters, such as detection distance, flow mode, and time on. Additional example 

15 sweens are shown in Fl^. 26d-26f and provide maintenance personnel with information 
that will reduce troubleshooting time and time to repair. The depicted screens represent 
preferred examples of the types and arrangements of information that may be available to 
maiutenance personnel on display screens provided by PCD 970. 

20 The block diagram of F^- 27 illustrates a more detailed view of control module 

926 and sensor module 958. The control module includes control logic 1003 for 
controlling the operation of remotely managed dispensiag apparatus 914. The control 
logic may be implemented in hardware, software or a combination thereof. In the 
preferred embodiment, the control logic 1003 is implemented in software and stored 

25 within a signal processor, such as, for example, a Motorola microprocessor 
(MC88HC908GP32CF8) having flash memory, analog-to-digital (A/D) converters and a 
variety of input and outputs as are described in the vendor's data sheets. When the 
remotely managed dispensing ^paratus 914 is implemented as a faucet that dispenses 
fluid into a sink, the electronics of the remotely managed dispensing apparatus 914 may 

30 preferably be located in sensor module 958 contained in the collar 912 of the faucet and 
in control module 926, which is typically mounted under the sink. The two modules 926, 
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958 may be electrically connected via cables 934 Q^. 24). In addition, a cable extends 
from file control module 926 to a latching solenoid valve 930 tbat directly controls fluid 
flow. The control module 926 is preferably positioned in a secure enclosure while the 
sensing electronics or sensor module 958 is preferably positioned on a sensor board 
5 potted in collar 912 of the faucet The potted arrangement reduces the likelihood that 
water will come into contact with the sensing electronics, and thus niiniinizes the risk of 
corrosion and other damage to these parts. 

The signal processor 1006 provides a detection signal 998 and a communication 
10 signal 999 for transmission from an IR emitter 960 in the sensor module 958. The 
detection sigual 998, preferably generated by the control logic 1003, is a sequence of one 
or more narrow pulses. In flie preferred embodiment, the pulses occur several times per 
second although other time intervals may be utilized in other embodiments. The 
detection signal is preferably seat to IR driver circuit 1004 and coupled via a cable to the 
15 IR emitt^ that wirelessly transmits the narrow IR pulses. In the preferred embodiment, 
one pulse is transmitted every 250 milliseconds. The detection signal is transmitted when 
the automatic dispensing apparatus is in a detection mode and the conununicadon signal 
is transmitted when Ae automatic dispensing j^paratus is in a coimnunication mode. The 
managed automatic dispensing apparatus in the preferred embodiment transfers from the 
20 communication mode back to the detection mode when control logic 1003 determines 
that all information has been exchanged 

Reflected detection signals are detected by an object photo detector 962 and are 
thereafler coi5)led to tibie signal processor 1006 via a detection receiver 1008. Oflier 

25 receiver elements such as a filter or aiiq)lifier, or both may be utilized to process the 
reflected signals detected by the object photo detector 962. In the detection mode, the 
managed automatic dispensing apparatus transmits a detection signal, receives reflected 
detection signals, and remains in the detection mode until there is a request to transfer to 
a communication mode. The communication mode request may be initiated by the 

30 portable communication device 970 as disclosed above and further described in co- 
pending U.S. Patent Application filed October 23, 2001, entitied, *T)ata Communications 
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System and Method for Communication Between Infi:aied Devices," and assigned 
Attorney 'docket No. 00-0895.16, which is hereby incorporated herein by reference, if 
desired, or may be initiated by the control logic 1003. A request by the PCD 970 for 
switching to the communication mode preferably is initiated by a transmission of a 

5 known digital sequence from the PCD 970. Once the known sequence is detected by the 
communication photo detector 964, communicated to control logic 1003 via 
communication receiver 1110 and verified by control logic 1003, the automatic 
dispensing apparatus 914 transitions to the communication mode. When the managed 
automatic dispensing apparatus 914 is in the communication mode, the control logic 1003 

10 transmits a communication signal to the IR emitter 960. The communication signal may 
require a boost from the IR driver circuit 1110 before being transmitted to the IR emitter 
960. The non lindting communication signal of the present invention may be based on 
the specifications described in an IR Data Association Specification and may be limited 
to half duplex transmission at or less than 9600 bps. Those skilled in the art could use a 

15 variety of modulation technologies to provide for information or data exchange. 

When the object photo detector 962 generates a signal in response to reflected 
signals fix)m an object, such as a person's hand, the signal is communicated to signal 
processor 1006. If the signal is greater than a threshold value, receive logic in the signal 

20 processor provides an open valve signal to a solenoid driver 931. Solenoid driver 931 
and any associated electrical components can be similar or identical to an H-bridge 
circuit described in U.S. patent 5,819,336, which is hereby incorporated herein by 
reference. The solenoid driver 931 is ad^ted to drive a latching solenoid valve 930 that 
opens in response to the open valve signal or closes in response to a close valve signal 

25 from the signal processor 1006. 

The control module 926 may be powered by one or more batteries 901 or by some 
other suitable power source. One embodiment of the present invention incorporates four 
(4) AA batteries in series (around 6 volts) coupled to a voltage regulator 1114 for 
30 providing a regulated voltage of fliree (3) volts for most of the electronics and uses six (6) 
volts to power the latching solmoid valve 930 and the IR emitter 960. An* audio output 
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1124 and LED output 1126 serve as troubleshooting indicators. For example, if the 
battery voltage is low, the LED preferably exhibits a defined on/oflf pattern. A battery 
monitor 1118 serves several functions. Under no-load conditions, the battery monitor 
1118 determines, comparing the battery voltage with a known voltage, if flie battery 
should be replaced In addition, the battery monitor 1118 may determine if the windings 
in the latching solenoid valve 930 are ia an open circuit condition or in a short circuit 
condition by observing the battery loading characteristics. Information fix)m the battery 
monitor 1118 may be sent to the portable communication device 970 when the remotely 
managed dispensing apparatus 914 is in the communication mode. In addition, an audio 
signal from the audio output device 1124 or a visual output from the LED output 1126 
may be used to notify maintenance technicians of a variety of identified problems. 

Fig. 28 is a block diagram illustration of timing aspects of the automatic 
dispensing apparatus 914 of the present mvention. The control logic 1003 preferably 
graerates a detection signal 998 when the managed automatic dispensing apparatus 914 is 
m the detection mode and preferably generates a data communication signal 999, for the 
upstream direction, when the managed automatic dispensmg apparatus 914 is in the 
communication mode. The control logic 1003 processor is configured to generate either 
the detection signal 998 or the communication signal 999, but tiie control logic 1003 
preferably does not generate the signals simultaneously. The signal generated by the 
control logic 1003 is sent to a digital-to-analog converter (DAQ 1134 and is preferably 
conditioned by driver circuit 1007. An ou^ut from the driver circuit 1006 is coupled 
over a communication link such as a wire to the IR emitter 960 in sensor module 958. 
Preferably, a transmit aperture 972 m collar 912 of the dispensmg device allows the 
mfrared signal to exit from an emitter lens integrated in IR emitter 960. Other 
arrangements of emitters, lenses, and apertures may provide other embodiments for 
transmission of mfrared signals. The method of generation of the above-mentioned 
transmit signals is not a limitation of the present invention. In the preferred embodiment, 
both the pulse width and the pulse height of the detection signal and communication 
signal may be controlled For example, the width of the signal preferably is controlled 
utilizmg transistors, and the height of the signal is preferably controlled by a digital value 
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sent to a DAC. The anangemeat of the transistors and the DAC conld be implranented 
by those skilled in the art 

Fig. 29 is a tuning diagram 944 showing an event repeat time 946, which is 
5 preferably approximately 250 milliseconds in the preferred embodiment Within the 
repeat time, there is an activity time 948 of around 200 microseconds. During flie 
activity time three samples are taken and stored within memory of the signal processor 
1006. In addition the control logic 1003 generates a detection signal 998, positioned in 
time as shown in F^. 29. Control logic 1003 samples the battery condition 951, then 
10 samples a reflection signal 952, and finally samples the ambient condition 953 (such as 
room lighting). The reflection sample 952 and ambient sample are taken from object 
photo detector 962. The reflection sampling occurs immediately after or as the detection 
signal, represented by pulse width 950 (approximately 60 microseconds), is transmitted. 
The ambient sampling is used to determine the light levels when no reflections occur. 
15 Those skilled in the art would appreciate that variations of tihe sampling times is not a 
limitation on the present invention. In general, narrow pulses pull less energy from the 
batt^ providing for energy savings, but narrow pulses contain higher frequencies than 
wide pulses. Components that process the higher frequencies associated with the narrow 
pulses typically cost more and a cost/efficiency factor is a design consideration. When 
20 the repeat time is 250 milliseconds as shown in Fig, 29, the activity time occurs 
approximately four (4) times per second. Experience has shown that this frequency of 
activity satisfies the needs of a person using the automatic dispensing unit of the present 
invention. The use of the ambient sanq)le and the reflection sample are inputs to an 
adjustment algorithm described in a co-pending U.S. Patent Application filed October 23, 
25 2001, entitled, "System and Method for Automatic Dynamic Calibration for Infirared 
Sensing Device" and assigned Attorney Docket No. 00-0895.19, which is hereby 
incorporated herein by reference. Although not specifically discussed in tiiis 
specification, initial system calibration is described in detail in a co-pending U.S. Patent 
AppUcation filed October 23, 2001, . entitied, 'Method of Automatic Standardized 
30 Calibration for Infrared Sensing Device," and assigned Attorney Docket No. 00-0895. 17, 
which is hereby incorporated by reference herein. In addition to the three samples 
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described above, oflier samples may be taken to detramine flie conditioii of elements 
within flie automatic dispensing ^paratus 914 of Ae present invention. For example, 
samples taken when the latohing solenoid valve 930 is activated may be used to 
deteimine changes in the required activation power. Oianges in the activation power 
5 may give an indication of the solenoid's condition or could indicate above normal 
pressure in the water supply line. Neither the number of samples, type of samples, or 
order of sauries is considered a limitation on the present invention. 

Fig. 30 is a block diagram showing a preferred receiver arrangement in 

10 accordance with the preferred electronically operated dispensing apparatus of the present 
invention. As shown in the diagrammatic illustration a detection receiver 1117 and a 
communication receiver 1118 are shown side-by-side. The detection receiver 1117 
includes object photo detector 962 coupled to a detection filter 1121. The output of 
detection filter .1121 preferably is coupled to and processed by the control logic 1003. 

15 The communication receiver 1123 includes the communication photo detector 964 
coupled to a decodw module 1119, the output of which is processed by the control logic 
1003. In one embodiment, the object photo detector 962 and the conununication photo 
detector 964 may be arranged badc-to-back (not shown). Various othrar embodiments, 
however, are also possible. For emnple, in another anbodiment a single jAoto detector 

20 could iHX)vide signals to the detection filtCT and a decodra- module. An arrangement of 
filters could also be used to sq)arate the lower firequendes of flie reflection signals fi»m 
Ihe hi^» j&equencies of flie communication signals. A more preferred embodiment will 
be described below with reference to Figs. 32a-32c. While only a single ^erture is 
shown in Fig. 30, a communication lens and detection lens may be mcorporated with 

25 photo detectors 962 and 964. The arrangement and location of tiie sqperture and lenses are 
not intended to limit the scope of the present invention. 

Fig. 31 illustrates an exemplary top view mounting arrangement for the IR emitter 
960 and die two IR detectors or photo detectors 962, 964. When the emitta: and detectors 
30 are mounted on a sensor Printed Circuit Board (PCB) of tiie sensor module 958, the PCB 
fits witiiin the collar 912 of the automatic dispensing apparatus 914. In addition to the 
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emitter and detectors, other electronic components (not shown) may reside on the PCB, 
As one of skill in the art will readily recognize, one or more cables preferably couple the 
PCB to the control module 926. 

5 Figs, 32a-32c illustrate a preferred firont-to-back arrangement for the two IR 

detectors or diodes 962, 964. Object photo diode 962 is mounted at the front of the 
sensor printed circuit board and the communication photo diode 964 is mounted behind 
and preferably ofiset sUghtly from photo diode 962. The diodes are preferably positioned 
some standoff distance from one another, and secured m the positions as shown, with 
10 transparent sihcone sealant fiU 967 as depicted in Fig. 32c. The object photo diode 962 
preferably includes an IR transmissive ^erture 973 that provides for IR signal coupling 
between an IR source, such as portable communication device 970, and communication 
photo diode 964. Generally peaking, the above mentioned arrangement allows IR 
signals to pass through aperture 973 to communication photo diode 964, thus providing 
15 better IR reception of data signals than the back-to-back arrangement Although oflier 
sensors may be employed in accordance with the present invention, the prefimred object 
photo diode 962 may be a diode identified by part number BPV23F and the 
communication photo detector 964 may be a diode identified by part number BPV22F, 
both of which are manufectured by Vishay Intertechnology, Inc.. The photo diodes 962, 
20 964 are preferably mounted on the sensor printed circuit board with conventional 
electronic components. In addition, and as indicated in Fig. 32c, the arrangement 
positioned behind a single aperture has the effect of minimizing interference &om 
undesired light sources, such as sunlight or room Ughting. 

25 Because the automatic dispensing apparatus 914 in the described embodnnent is 

battery powered, it may be desirable to utilize a battery savings methodology. Such a 
battery saving metiiodology is embodied when the control logic 1003 configures flie 
signal processor 1006 to operate in an on mode, a wait mode, and a stop mode. When the 
automatic dispensing apparatus 914 is installed and functioning, the signal processor is in 

30 ttie on mode approximately 2.8% of tiie time, the stop mode nearly 97% of the time, and 
the wait mode for around 0.2% of the time. A low fi:equency clock firequency of 32.768 
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KHz is preferably applied to flie signal processor during Ihe stop mode allowing the 
signal processor to operate on about 50 microanips. When a timer, fiinctioning in Ae 
stop mode, reaches a given vahie, the signal processor transitions to flie on mode. During 
the on mode the clock frequency for the signal processor is proximately 4 MHz, 

5 requiring an operational current of about 4 milliamps for the signal processor. The wait • 
mode requires around 1 milUamp of current, and is used for special purposes, such as 
providing power for operation of the control logic for the latching solenoid drivers during 
a transition between the on mode and the stop mode. Where the detection signal is an 
emitter pulse that is preferably sent 4 times per second with a pulse width of around 59 

10 microseconds, the power requirement for the emitter 960 of the automatic dispensing 
apparatus 914 is significantly reduced. Conventional dispensing devices send pulses 
around 8 times per second with a pulse width of over 200 microseconds. In addition, 
modifications to the latchmg solenoid valve circuits have provided an additional 
reduction in energy tequiremoits. 

15 

The battoy saving methodology described above allows an embodiment of the 
remotely managed automatic dispensing apparatus to operate on four (4) AA batteries, 
where each battery is enable of siqjplying around 2500 mAhours. Conventional 
dispensing devices typically require four (4) C batteries, where each battery is capable of 
20 supplymg around 7100 mAhours. The reduction, of nearly 65%, m power requirements 
and the associated benefits of reduced cost and size represents a significant improvement 
over conventional dispensing devices. 

In the preferred embodiment, the present invention normally operates in the 
25 detection mode, to provide the function of dispensing water. A method or procedure is 
provided in accordance with ttie present hivention to transfo: from the detection mode to 
the communication or data mode. Since the PDA communication protocol is ^ferably 
based on the IRDA specifications, it is preferable to send a known sequence to ttie sensor 
module 958 from the portable communication device 970 for at least 300 milliseconds 
30 since the operational mode for the control module 926 ^ically occurs for a brief amount 
of time every 250 milliseconds. When das control module detects the known sequfflice a 
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detection mode to conmninication mode transition is initiated as desoibed more detail 
above. 

While the invention has been desc^bed in detail, it is to be e7q)ressly understood 
5 that it will be apparent to persons skilled in the relevant art that the invoition may be 
modified without departing from the spirit of the inventioiL Various changes of form, 
design or arrangement may be made to the invention without departing from the spirit 
and scope of the invention. For example, the invention as described is not dependent 
upon specific hardware configurations, nor is it pivotal to employ a specific programming 
10 language to implement tihie invention as described. Additionally, the reflective filtering 
techniques described in the co-pending U.S. Patent Application filed, October 23, 2001, 
entitled, "System and Method for Filtering Reflected Infirared," and assigned Attorney 
Docket No. 00-0895.15, which is hereby incorporated by reference herein, may forma 
part of the present inventioiL Therefore, Ihe above mentioned description is to be 
15 considered exemplary, rather than limiting, and the true scope of the invention is that 
defined in the following claims 
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What is claimed is: 

1 . A wireless data exchange system comprising: 

an electronically operated appliance including a transmitter, a receiver, and a 
control module configured to communicate witii the transmitter and Ihe receiver, the 
control module being configured to provide a primary mode of operation and a secondary 
mode of operation and including control logic configured to selectively change the mode 
of operation of the electronically operated appliance; and 

a communication device adapted to be held in the hand of a user and configured 
to cooperate with the transmitter and the receiver to impart instructions wirelessly to the 
control logic to change the mode of operation of the electronically operated appUance 
\xpon receipt of a command from a user. 

2. The system of claim 1, wherein the receiver comprises a first receiver and a 
second receiver, and wherein said primary mode of operation comprises a sensing mode 
and said secondary mode of operation comprises a communication mode, the first 
receiver being configured to operate in the sensing mode and the second receiver beuig 
configured to operate in the communication mode. 

3. The system of claim 1, wherein the transmitter comprises an active infi:ared 
emitter configured to selectively emit sensmg signals capable of being received by the 
receiver and communication signals capable of being received by said communication 
device. 

4. The system of claim 3, wherebi the receiver comprises an infrared detector 
capable of detecting a communication signal and a sensing signal. 

5. The system of claim 4, wherein said electronically operated appliance comprises 
an electronically operated fluid dispensing device. 
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6. The system of claim 1, wherein said communication device inchides a 
communication receiver and a microprocessor, and wherein tiie communication receiver 
and the microprocessor cooperate to receive signals firom said electronically operated 
appliance, identify the electronically operated appliance and detennine tiie operating 
status of the electronically operated appliance. 

7. The system of claim 6, wherein said communication device further includes an 
emitter that communicates with the microprocessor to transmit signals to the 
electronically operated appliance in response to signals received from said electronically 
operated apphance, the transmitted signals mcluding instructions that change the 
operating parametm of said electronically operated appliance. 

8. A method of exchanging data wirelessly between an apparatus and a 
communication device, said metiiod comprising the steps of: 

sending a wireless signal from a handheld communication device to an 
electronically operated appliance operating in a primary mode of operation; 

changing the mode of operation of the electronically operated appliance from a 
primary mode of operation to a secondary mode of operation in response to said sending 
step; and 

establishing a two-way wireless communication Unk for the ^change of data 
between the handheld device and the electronically operated ^liance while the 
electronically opa:ated appliance is in tiie secondary mode of operation. 

9. The method of claim 8, wherein said handheld communication device includes a 
display screen, said method further comprisuig the step of displaying the operating status 
of the electronically operated appliance on tiie display screen. 

10. The method of claim 9 further comprisiag the step of transmitting an infrared 
signal from the handheld corrunxmication device to the electronically operated appliance 
in response to the displaying step in order to change the operating parameters of the 
electronically operated appliance. 
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